IntentService源碼分析

1 概論

IntentService是一種處理異步請(qǐng)求的Service。客戶端通過(guò)調(diào)用Context.startService(Intent)來(lái)發(fā)送請(qǐng)求,啟動(dòng)Service;Service按需啟動(dòng)后,會(huì)依次按順序處理工作線程中的Intent,并且在工作結(jié)束后會(huì)自動(dòng)停止。

2 IntentService是如何啟動(dòng)一個(gè)異步線程處理請(qǐng)求的?

IntentService在創(chuàng)建時(shí),會(huì)創(chuàng)建并啟動(dòng)一個(gè)線程HandlerThread,并且賦予這個(gè)線程一個(gè)Looper;

@Override
    public void onCreate() {
        super.onCreate();
        HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
        thread.start();
        mServiceLooper = thread.getLooper();
        mServiceHandler = new ServiceHandler(mServiceLooper);
    }

ServiceHandler是Handler的一個(gè)子類,用來(lái)接受處理消息Message,我們知道一般Handler是在UI主線程接受處理消息的,要想在異步線程接受處理消息,必須給這個(gè)異步線程關(guān)聯(lián)一個(gè)Looper,并且在異步線程調(diào)用Looper.prepare()方法;

public class HandlerThread extends Thread {
    int mPriority;
    int mTid = -1;
    Looper mLooper;
    
    public HandlerThread(String name) {
        super(name);
        mPriority = Process.THREAD_PRIORITY_DEFAULT;
    }
    ...
    @Override
    public void run() {
        mTid = Process.myTid();
        Looper.prepare();
        synchronized (this) {
            mLooper = Looper.myLooper();
            notifyAll();
        }
        Process.setThreadPriority(mPriority);
        onLooperPrepared();
        Looper.loop();
        mTid = -1;
    }
    ...
}

3 IntentService是如何處理Intent的

調(diào)用Context.startService(Intent)后,Service被啟動(dòng),執(zhí)行onCreate()方法,然后執(zhí)行onStart(Intent intent,int startId);

    public void onStart(Intent intent, int startId) {
        Message msg = mServiceHandler.obtainMessage();
        msg.arg1 = startId;
        msg.obj = intent;
        mServiceHandler.sendMessage(msg);
    }

可以看到Service開(kāi)始后,會(huì)把Intent對(duì)象通過(guò)Handler機(jī)制交給ServiceHandler來(lái)處理,ServiceHandler接受到消息后:

    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);
        }
    }

ServiceHandler接受到消息后,取出Intent,啟動(dòng)onHandleIntent(Intent) 方法,來(lái)處理Intent;

我們來(lái)看onHandleIntent(Intent intent);

protected abstract void onHandleIntent(Intent intent);

這是一個(gè)抽象方法,留給開(kāi)發(fā)者自己實(shí)現(xiàn),異步操作的實(shí)現(xiàn)邏輯都在這個(gè)抽象方法里面;操作完成后,通過(guò)調(diào)用stopSelf() Service

4 總結(jié)

  1. IntentService在創(chuàng)建的時(shí)候會(huì)創(chuàng)建一個(gè)線程,并啟動(dòng)這個(gè)異步線程;
  2. 創(chuàng)建的異步線程會(huì)利用Looper、Handler來(lái)創(chuàng)建、發(fā)送、接受消息Message,與UI主線程通過(guò)Handler機(jī)制進(jìn)行線程通信是同理的;
  3. Service的異步操作邏輯是定義在抽象方法onHandleIntent(Intent)里面,開(kāi)發(fā)者需要實(shí)現(xiàn)這個(gè)抽象方法;
  4. ServiceHandler處理消息是在異步線程里面的,onHandleIntent(Intent)也是運(yùn)行在異步線程里面的,這與UI主線程里面的Handler不同;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容