停止使用 HandlerThread 启动的服务
Stop a Service started with an HandlerThread
我使用 HandlerThread 创建了一个 运行 任务的服务。
为了可读性问题,我简化了我的代码。
从 activity 中单击一个按钮,我将启动打印数字 1 到 10 的服务。从同一个 activity 中,我将有机会通过按停止键来停止该服务按钮。如果我单击停止按钮,则会调用服务的 OnDestroy 方法,但我的任务会继续 运行,直到打印出从 1 到 10 的数字。
提前感谢您的回复。
public class DownloadService extends Service {
private Looper mServiceLooper;
private ServiceHandler mServiceHandler;
private LocalBroadcastManager mLocalBroadcastManager;
private HandlerThread thread;
private final class ServiceHandler extends Handler {
public ServiceHandler(Looper looper) {
super(looper);
}
@Override
public void handleMessage(Message msg) {
for(int i = 0; i < 10; i++) {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}
stopSelf(msg.arg1);
}
}
@Override
public void onCreate() {
thread = new HandlerThread("ServiceStartArguments", android.os.Process.THREAD_PRIORITY_BACKGROUND);
thread.start();
// Get the HandlerThread's Looper and use it for our Handler
mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);
mLocalBroadcastManager = LocalBroadcastManager.getInstance(this);
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Message msg = mServiceHandler.obtainMessage();
Bundle b = new Bundle();
b.putInt("message", intent.getIntExtra("message", 0));
msg.setData(b);
msg.arg1 = startId;
mServiceHandler.sendMessage(msg);
return START_NOT_STICKY;
}
@Override
public IBinder onBind(Intent intent) {
throw new UnsupportedOperationException("Not yet implemented");
}
@Override
public void onDestroy() {
Log.d(TAG, "DESTROY");
super.onDestroy();
}
}
在服务 onDestroy 中,中断 运行 线程:
thread.interrupt();
thread.quit();
然后,当您的睡眠被打断时,跳出循环,以便线程可以通过从 handleMessage 方法返回来终止。
编辑:我要补充的是,在 HandlerThread 上执行一些工作期间,睡眠有点像 "bad form"。如果您需要定期安排工作,您可以通过将延迟消息发布到 Handler/HandlerThread 来安排这些工作。然后你可以 quit
线程而不必中断它。
我使用 HandlerThread 创建了一个 运行 任务的服务。 为了可读性问题,我简化了我的代码。
从 activity 中单击一个按钮,我将启动打印数字 1 到 10 的服务。从同一个 activity 中,我将有机会通过按停止键来停止该服务按钮。如果我单击停止按钮,则会调用服务的 OnDestroy 方法,但我的任务会继续 运行,直到打印出从 1 到 10 的数字。
提前感谢您的回复。
public class DownloadService extends Service {
private Looper mServiceLooper;
private ServiceHandler mServiceHandler;
private LocalBroadcastManager mLocalBroadcastManager;
private HandlerThread thread;
private final class ServiceHandler extends Handler {
public ServiceHandler(Looper looper) {
super(looper);
}
@Override
public void handleMessage(Message msg) {
for(int i = 0; i < 10; i++) {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}
stopSelf(msg.arg1);
}
}
@Override
public void onCreate() {
thread = new HandlerThread("ServiceStartArguments", android.os.Process.THREAD_PRIORITY_BACKGROUND);
thread.start();
// Get the HandlerThread's Looper and use it for our Handler
mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);
mLocalBroadcastManager = LocalBroadcastManager.getInstance(this);
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Message msg = mServiceHandler.obtainMessage();
Bundle b = new Bundle();
b.putInt("message", intent.getIntExtra("message", 0));
msg.setData(b);
msg.arg1 = startId;
mServiceHandler.sendMessage(msg);
return START_NOT_STICKY;
}
@Override
public IBinder onBind(Intent intent) {
throw new UnsupportedOperationException("Not yet implemented");
}
@Override
public void onDestroy() {
Log.d(TAG, "DESTROY");
super.onDestroy();
}
}
在服务 onDestroy 中,中断 运行 线程:
thread.interrupt();
thread.quit();
然后,当您的睡眠被打断时,跳出循环,以便线程可以通过从 handleMessage 方法返回来终止。
编辑:我要补充的是,在 HandlerThread 上执行一些工作期间,睡眠有点像 "bad form"。如果您需要定期安排工作,您可以通过将延迟消息发布到 Handler/HandlerThread 来安排这些工作。然后你可以 quit
线程而不必中断它。