我有一项由 Activity 启动(未绑定(bind))的服务。如果 Activity 被破坏(例如通过按下后退按钮),服务将继续运行,这当然是有意的。 但是,如果我将 Activity 从“最近的应用程序”列表中滑出,该服务会立即重新启动。这是可重现的,每次将 Activity/应用程序从列表中滑出时,都会对服务的 onCreate 方法进行一次新调用。中间不要调用 onDestroy!
首先我认为服务被 android 杀死了,尽管我没有看到杀死的原因( Activity 和服务都没有做资源消耗的事情,实际上它们是极简的并且什么都不做)。但后来我注意到该服务实际上崩溃了。
V/MainActivity(856): onDestroy // swipe out of the list
I/ActivityManager(287): Killing 856:com.example.myapp/u0a10050: remove task
W/ActivityManager(287): Scheduling restart of crashed service com.example.myapp/.TestService in 5000ms
代码不值得注意,但在这里
Activity :
public class MainActivity extends Activity {
private static final String TAG = "MainActivity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.v(TAG, "onCreate, starting service...");
startService(new Intent(this, TestService.class));
}
@Override
protected void onStart() {
super.onStart();
Log.v(TAG, "onStart");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.v(TAG, "onDestroy");
}
//[...]
}
服务:
public class TestService extends Service {
private static final String TAG = "Service";
// onBind omitted
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.v(TAG, "onStartCommand");
return super.onStartCommand(intent, flags, startId);
}
@Override
public void onDestroy() {
super.onDestroy();
Log.v(TAG, "onDestroy");
}
}
简而言之: 我的服务独立于 Activity 的生命周期,但前提是我不刷出最近应用列表的应用。在这种情况下,服务会重新启动,但不会调用 onDestroy。
每次发生这种情况,不仅服务的状态,而且服务正在做的工作都会丢失。我只是想知道为什么滑动是这个原因。
最佳答案
从最近的任务列表中滑动应用实际上会杀死托管该应用的操作系统进程。由于您的服务与您的 Activity 在同一进程中运行,因此这有效地终止了该服务。它不会在服务上调用 onDestroy()
。它只是杀死了这个过程。繁荣。死的。走了。您的服务不会崩溃。
由于您的服务从对 onStartCommand()
的调用中返回了 START_STICKY
,Android 识别出您的服务应该重新启动并安排重新启动被终止的服务。但是,当您的服务重新启动时,它将处于一个新创建的进程中(您可以看到服务中调用了 onCreate()
),因此它必须重新开始工作。
规则 #1:永远不要从最近的任务列表中滑动应用 ;-)
关于应用从最近应用列表中刷出后,Android 服务崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18612880/