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")。但是,您的进程可能随时终止。
我只是针对 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")。但是,您的进程可能随时终止。