IntentService簡介
是一種特殊的Service,繼承了Service并且是個(gè)抽象類,可用于執(zhí)行后臺(tái)耗時(shí)任務(wù),當(dāng)任務(wù)結(jié)束后自動(dòng)停止,同時(shí)由于是服務(wù)的原因,它的優(yōu)先級(jí)比普通線程高很多,因此不容易被系統(tǒng)殺死。在實(shí)現(xiàn)上,IntentService封裝了HandlerThread和Handler。
基本流程
startService(intentService):
onCreate()->
onStartCommand()->
onStart()->
sendMessage()->
handlerMessage()->
onHandlerIntent()->
stopSelf(startId)->
onDestroy->
詳細(xì)解剖
onCreate()
當(dāng)服務(wù)第一次創(chuàng)建的時(shí)候調(diào)用onCreate()
@Override
public void onCreate() {
// TODO: It would be nice to have an option to hold a partial wakelock
// during processing, and to have a static startService(Context, Intent)
// method that would launch the service & hand off a wakelock.
super.onCreate();
HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
thread.start();
mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);
}
該方法封裝了HandlerThread 和 Handler
onStartCommand()
每一次啟動(dòng)服務(wù)的時(shí)候調(diào)用onStartCommand()
@Override
public int onStartCommand(@Nullable Intent intent, int flags, int startId) {
onStart(intent, startId);
return mRedelivery ? START_REDELIVER_INTENT : START_NOT_STICKY;
}
該方法僅僅調(diào)用了onStart()方法
onStart()
@Override
public void onStart(@Nullable Intent intent, int startId) {
Message msg = mServiceHandler.obtainMessage();
msg.arg1 = startId;
msg.obj = intent;
mServiceHandler.sendMessage(msg);
}
該方法把startService傳來的Intent和startId封裝成Message消息,然后通過handler發(fā)送消息,接著執(zhí)行mServiceHandler.handleMessage()
其中ServiceHandler是IntentService的一個(gè)內(nèi)部類,它的定義如下
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);
}
}
handleMessage()
@Override
public void handleMessage(Message msg) {
onHandleIntent((Intent)msg.obj);
stopSelf(msg.arg1);
}
該方法會(huì)執(zhí)行onHandleIntent()方法,它是個(gè)抽象方法,因此我們自定義IntentService的時(shí)候必須重寫onHandleIntent()方法。因?yàn)榘l(fā)送消息那那個(gè)handler是HandlerThread所關(guān)聯(lián)的,所以處理信息的時(shí)候是在子線程進(jìn)行的。不會(huì)的可以看看HandlerThread原理。
stopSelf()
@Override
public void handleMessage(Message msg) {
onHandleIntent((Intent)msg.obj);
stopSelf(msg.arg1);
}
當(dāng)onHandleIntent()方法執(zhí)行完畢之后,會(huì)調(diào)用stopSelf(int)方法結(jié)束服務(wù)
onDestroy()
@Override
public void onDestroy() {
mServiceLooper.quit();
}
最后銷毀服務(wù)的時(shí)候,終止線程執(zhí)行