Primary/Android
lifecycleOwner vs. viewLifecycleOwner
해스끼
2023. 3. 17. 22:36
Fragment도 Activity와 유사한 lifecycle을 갖는다. ``Lifecycle.State`` enum에서 모든 상태 값을 확인할 수 있다.
- ``INITIALIZED``
- ``CREATED``
- ``STARTED``
- ``RESUMED``
- ``DESTROYED``
그런데 fragment의 view는 fragment와 별도의 lifecycle을 갖는다. 뷰가 보이지 않지만 fragment 자체는 살아있을 수 있기 때문이다. View binding을 ``onCreate``가 아닌 ``onCreateView``에서 초기화하는 이유이기도 하다.
최근 본 코드 중에 fragment에서 ``LiveData``를 observe하는 코드가 있었는데, 생명주기를 ``lifecycleOwner``로 설정하니 메모리 누수가 탐지되었다. 이유인즉슨 fragment의 view가 destroy되었으므로 ``LiveData``도 observe를 멈춰야 하는데, 생명주기가 ``lifecycleOwner``에 맞춰져 있어서 계속 observe되고 있었기 때문이다.
``lifecycleOwner`` 대신 ``viewLifecycleOwner``를 사용하면 메모리 누수가 발생하지 않는다.
Fragment UI와 관련된 코드에서는 가급적 ``viewLifecycleOwner``를 사용하자.
참고한 글