Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Is Activity.onStop() guaranteed to be called (API 11 +)

It is unclear (to me, at least) from the documentation whether Activity.onStop is guaranteed to be called. There are two places with seemingly contradictory information.

  1. Javadoc for Activity.onStop:

Note that this method may never be called, in low memory situations where the system does not have enough memory to keep your activity's process running after its onPause() method is called.

  1. Documentation (in particular 'Killable' column) for Activity class http://developer.android.com/reference/android/app/Activity.html#ActivityLifecycle:

Starting with Honeycomb, an application is not in the killable state until its onStop() has returned. This impacts when onSaveInstanceState(Bundle) may be called (it may be safely called after onPause() and allows and application to safely wait until onStop() to save persistent state.

It's a bit of a struggle to find a way that both pieces of documentation are telling the truth. The only scenario I can think of is this: Suppose you are developing on target API 21 (with min sdk 10) and write an Activity with an onStop() method. If you then run this application on an API 10 phone, onStop() is not guaranteed to be called. This scenario means that the documentation from points 1. and 2. above are both true. Otherwise, one of them must be false.

like image 215
Villa Avatar asked Apr 01 '15 15:04

Villa


People also ask

Is onStop guaranteed to be called?

If you then run this application on an API 10 phone, onStop() is not guaranteed to be called. This scenario means that the documentation from points 1. and 2. above are both true.

Is onStop guaranteed to be called Android?

For all devices, onStop is killable. It is not guarantee to be called.

What is onStop () activity?

Summary: onStop() method is called after onPause() method when activity goes in background. This method can be used to stop Api calls etc.

Is onPause always called before onStop?

onPause() is always called. This is guaranteed. If you need to save any state in your activity you need to save it in onPause() . onStop() may be called after onPause() , or it may not.


2 Answers

Is Activity.onStop() guaranteed to be called (API 11 +)

Yes, it is guaranteed to be called on post-Honeycomb devices (API 11 +)

Source 1: Video tutorial on Activity life cycle - taught by Google developer advocate

Source 2: https://developer.android.com/reference/android/app/Activity.html#ActivityLifecycle

Image screenshot from developer.android.com

Source 3: AndroidLifeCycle article on www.vogella.com

Image screenshot from www.vogella.com

like image 50
AnV Avatar answered Oct 17 '22 14:10

AnV


If you look further down in the ActivityLifeCycle reference, it says:

For those methods that are not marked as being killable, the activity's process will not be killed by the system starting from the time the method is called and continuing after it returns. Thus an activity is in the killable state, for example, between after onPause() to the start of onResume().

Since this appears to re-inforce point #1, I would err on the conservative side and design and plan my code as if point #1 were true and ignore point #2.

like image 1
Phileo99 Avatar answered Oct 17 '22 15:10

Phileo99