Android IntentService 工作原理
IntentService簡介
是一種特殊的Service,繼承了Service並且是個抽象類,可用於執行後臺耗時任務,當任務結束後自動停止,同時由於是服務的原因,它的優先順序比普通執行緒高很多,因此不容易被系統殺死。在實現上,IntentService封裝了HandlerThread和Handler。
基本流程
startService(intentService):
onCreate()->
onStartCommand()->
onStart()->
sendMessage()->
handlerMessage()->
onHandlerIntent()->
stopSelf(startId)->
onDestroy->
詳細解剖
onCreate()
當服務第一次建立的時候呼叫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()
每一次啟動服務的時候呼叫onStartCommand()
@Override
public int onStartCommand(@Nullable Intent intent, int flags, int startId) {
onStart(intent, startId);
return mRedelivery ? START_REDELIVER_INTENT : START_NOT_STICKY;
}
該方法僅僅呼叫了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傳送訊息,接著執行mServiceHandler.handleMessage()
其中ServiceHandler是IntentService的一個內部類,它的定義如下
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);
}
該方法會執行onHandleIntent()方法,它是個抽象方法,因此我們自定義IntentService的時候必須重寫onHandleIntent()方法。因為傳送訊息那那個handler是HandlerThread所關聯的,所以處理資訊的時候是在子執行緒進行的。不會的可以看看HandlerThread原理。
stopSelf()
@Override
public void handleMessage(Message msg) {
onHandleIntent((Intent)msg.obj);
stopSelf(msg.arg1);
}
當onHandleIntent()方法執行完畢之後,會呼叫stopSelf(int)方法結束服務
onDestroy()
@Override
public void onDestroy() {
mServiceLooper.quit();
}
最後銷燬服務的時候,終止執行緒執行
相關文章
- Android中IntentService的原理及使用AndroidIntent
- 理解 IntentService 原理Intent
- Android IntentServiceAndroidIntent
- 淺談IntentService原理分析Intent
- Android 使用IntentServiceAndroidIntent
- IntentService 和 HandlerThread 的原理Intentthread
- Android面試相關 - IntentServiceAndroid面試Intent
- Android中IntentService原始碼分析AndroidIntent原始碼
- Android IntentService 的使用和解析AndroidIntent
- Android View 的工作原理AndroidView
- Android多執行緒之IntentServiceAndroid執行緒Intent
- Android View的工作原理(上)AndroidView
- Android IntentService完全解析 當Service遇到HandlerAndroidIntent
- IntentServiceIntent
- Android後臺任務(HandlerThread、AsyncTask、IntentService)AndroidthreadIntent
- Android中IntentService的使用及其原始碼解析AndroidIntent原始碼
- 深入解析 Android 中 View 的工作原理AndroidView
- IntentService小酌Intent
- Android四大元件之Service,以及IntentServiceAndroid元件Intent
- Android IntentService使用全面介紹及原始碼解析AndroidIntent原始碼
- Android程式間通訊,AIDL工作原理AndroidAI
- 原始碼解析Android中AsyncTask的工作原理原始碼Android
- IntentService的使用Intent
- IntentService原始碼Intent原始碼
- IntentService簡介Intent
- Android Service和IntentService知識點詳細總結AndroidIntent
- 從crash看kotlin-android-extensions工作原理KotlinAndroid
- Android開發藝術(3)——View的工作原理AndroidView
- 2018.03.16、Android-IntentService學習筆記AndroidIntent筆記
- IntentService,用完即走Intent
- 看完這一篇,再也不怕面試官問到IntentService的原理面試Intent
- Android Studio的Instant Run工作原理及用法Android
- Android中Google Authenticator驗證系統工作原理分析AndroidGo
- require工作原理UI
- Mybatis工作原理MyBatis
- Nginx工作原理Nginx
- Handler 工作原理
- rman工作原理