应用从最近应用列表中刷出后,Android 服务崩溃

标签 android android-service

我有一项由 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/

相关文章:

android - android xml中app命名空间的用途是什么

java - Android Studio登录系统数据库问题

java - 使用 SSH 将文件从 Android 应用程序发送到树莓派

android - 持久服务

Android:IntentService 未正确排队

android - 关于最低所需的 SDK、目标 SDK、使用 Android 中的选项进行编译

android - 如何在 ListView 中获取值形式的编辑文本?

Android 与跨多个应用的​​现有服务绑定(bind)

android - 在 Android 中恢复 Activity 状态

android - 使用生命周期问题