Service:不能运行在独立的线程,所以不建议在Service中编写耗时的逻辑和操作,否则20s内没执行完会引起ANR。
IntentService:
1、任务在子线程中执行,可用于执行后台耗时的任务,任务执行后会自动停止。
2、具有高优先级,适合高优先级的后台任务,且不容易被系统杀死。
3、可以多次启动,每个耗时操作都会以工作队列的方式在Intent Service的onHandleIntent回调方法中执行。
下面通过分析IntentService 源码来解释一下IntentService的几个特点:
public abstract class IntentService extends Service {
...
@Override
public void onCreate() {
super.onCreate();
HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
thread.start();
mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);
}
...
}
public class HandlerThread extends Thread {
...
public HandlerThread(String name) {
super(name);
//public static final int THREAD_PRIORITY_DEFAULT = 0;
mPriority = Process.THREAD_PRIORITY_DEFAULT;
}
...
}
IntentService在onCreate()方法中创建了优先级为0的高优先级HandlerThread,所以然后通过HandlerThread的Looper创建了ServiceHandler,可以看出ServiceHandler是运行在高优先级的子线程中,适合高优先级的后台任务。
public abstract class IntentService extends Service {
...
private final class ServiceHandler extends Handler {
public ServiceHandler(Looper looper) {
super(looper);
}
@Override
public void handleMessage(Message msg) {
onHandleIntent((Intent)msg.obj);
stopSelf(msg.arg1);
}
}
@Override
public void onStart(@Nullable Intent intent, int startId) {
Message msg = mServiceHandler.obtainMessage();
msg.arg1 = startId;
msg.obj = intent;
mServiceHandler.sendMessage(msg);
}
...
}
IntentService的onStart()方法中通过mServiceHandler.sendMessage(msg)回调到ServiceHandler的handleMessage(Message msg)方法中,此方法中调用了onHandleIntent((Intent)msg.obj);由此可知onHandleIntent是在子线程中执行任务,也是在Handler队列中执行,所以多次启动IntentService时,每个耗时操作都是以工作队列的方式在Intent Service的onHandleIntent回调方法中执行。随后调用了stopSelf(msg.arg1),在onHandleIntent任务执行结束后自动停止。
IntentService时序图如下: