Из DOCS объект Context содержит глобальную информацию о среде приложения.Он позволяет получить доступ к ресурсам и классам, относящимся к конкретному приложению, а также к дополнительным вызовам для операций на уровне приложения, таких как запуск, широковещание и получение и т. Д.
метод getContext()
возвращает контекст, связанный стекущий объект, который может быть представлением, фрагментом или диалогом или любым другим объектом, для которого этот метод определен или наследуется.
метод getActivity()
возвращает ссылку на текущую активность, связанную сФрагмент объекта.Если с фрагментом нет активности, он вернет null
.Лично я никогда не использую этот метод при передаче аргумента контекста, я использую только getContext()
и getApplicationContext()
.
getApplicationContext()
особенно полезно, потому что он использует контекст, жизненный цикл которого отделен от текущего контекста, онпривязан к времени жизни процесса, а не к текущему компоненту.Это означает, что он использует контекст приложения, а не части приложения, как действие. см. Здесь
Рекомендации по использованию контекста:
getContext()
и getApplicationContext()
достаточно для передачи аргумента контекста.Если они не доступны сразу, вы можете использовать цепочку getActivity().getApplicationContext()
для передачи соответствующего аргумента контекста.Это означает, что вы можете использовать это для создания Toasts
, AlertDialogs
, Intents
, Fragments
и других манипуляций представления, которые требуют контекста. - Никогда не назначайте контекст статической (классовой) переменной, Itсоздаст утечку памяти!
- Если вы используете
getApplicationContext()
для регистрации трансляций, вы должны выполнить соответствующую очистку, чтобы предотвратить утечки памяти. см. Здесь
Обратите внимание, что это мои личные подходы, я должен быть исправлен:).