Android O - 后台服务限制未按预期工作

Android O - Background service limitation not working as expected

我只是针对 Android O 背景限制测试我现有的 android 应用程序。

在测试中,我发现了一个奇怪的行为。所以基本上在我的应用程序中,我正在使用后台服务,并且我首先 activity.

启动它

所以现在的问题是一旦 activity 和后台服务启动,我将使用后退按钮关闭我的 activity。因此,根据服务概念,它在后台保持 运行。

大约 1 分钟后 onDestroy() 调用了后台服务方法,但服务仍然保持 运行。理想情况下,根据文档,它应该被杀死。

所以,我不知道这是问题还是什么。

作为参考,我创建了一个示例代码,它反映了如下相同的场景:

步骤

HomeActivity.java

package com.icpl.otest;

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;

import com.icpl.otest.service.MyService;

public class HomeActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_home);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
    }

    public void onStartServiceClick(View view) {
        Intent serviceIntent = new Intent(this, MyService.class);
        startService(serviceIntent);
    }
}

MyService.java

package com.icpl.otest.service;

import android.app.Service;
import android.content.Intent;
import android.os.Handler;
import android.os.IBinder;
import android.util.Log;

public class MyService extends Service {
    private static final String TAG = "MyService";

    private Handler mHandler;

    public MyService() {
        Log.i(TAG, "MyService constructor called.");
        mHandler = new Handler();
    }

    @Override
    public IBinder onBind(Intent intent) {
        throw new UnsupportedOperationException("Not yet implemented");
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        Log.i(TAG, "onStartCommand with intent:- " + intent);
        startShowingVisibility();
        return START_NOT_STICKY;
    }

    private void startShowingVisibility() {
        mHandler.postDelayed(new Runnable() {
            @Override
            public void run() {
                Log.i(TAG, "I am alive");
                startShowingVisibility();
            }
        }, 3000);
    }

    @Override
    public void onDestroy() {
        Log.i(TAG, "onDestroy()");
        super.onDestroy();
    }
}

After approx 1 min onDestroy() method gets called of background service but still the service keeps running

不,不是。您的服务可能已经开始的 工作 可能会继续进行(在您的情况下,您的无限 Handler "loop")。但是,您的进程可能随时终止。