android IntentService實現(xiàn)原理及內(nèi)部代碼分享
更新時間:2013年06月02日 15:23:43 作者:
android IntentService實現(xiàn)原理及內(nèi)部代碼分享,需要的朋友可以參考一下
很多網(wǎng)友可能發(fā)現(xiàn)Android中除了Service還有一個IntentService,他們之間到底有哪些區(qū)別呢? 在繼承關(guān)系上而言IntentService是Service的子類,內(nèi)部實現(xiàn)的代碼中涉及到一些Android入門開發(fā)者不了解的Looper,Android123在早期的文章中已經(jīng)說明他們的用法,這里不再贅述,有關(guān)原理大家可以看源碼實現(xiàn)如下:
public abstract class IntentService extends Service {
private volatile Looper mServiceLooper;
private volatile ServiceHandler mServiceHandler; //一個Handler封裝了Looper對象
private String mName;
private boolean mRedelivery;
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);
}
}
public IntentService(String name) { //構(gòu)造方法,需要提供一個name作為標識
super();
mName = name;
}
對于下面的setIntentRedelivery的參數(shù),如果為真時
onStartCommand(Intent, int, int)} will return
Service#START_REDELIVER_INTENT}, so if this process dies before
onHandleIntent(Intent)} returns, the process will be restarted
如果為假時
onStartCommand(Intent, int, int)} will return
Service#START_NOT_STICKY}, and if the process dies
public void setIntentRedelivery(boolean enabled) {
mRedelivery = enabled;
}
@Override
public void onCreate() { //這里重寫父類Service的創(chuàng)建,主要是構(gòu)造一個線程
super.onCreate();
HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
thread.start();
mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);
}
@Override
public void onStart(Intent intent, int startId) { //Android 2.0以前的Service啟動參數(shù)控制
Message msg = mServiceHandler.obtainMessage();
msg.arg1 = startId;
msg.obj = intent;
mServiceHandler.sendMessage(msg);
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) { //Android 2.0以后的服務啟動參數(shù)
onStart(intent, startId);
return mRedelivery ? START_REDELIVER_INTENT : START_NOT_STICKY;
}
@Override
public void onDestroy() { //服務摧毀的時候Looper一定要釋放掉,這點很重要。
mServiceLooper.quit();
}
@Override
public IBinder onBind(Intent intent) {
return null;
}
protected abstract void onHandleIntent(Intent intent);
}
從上面的代碼相信大家可以看出IntentService和Service的不同了,通過Looper和Thread來解決標準Service中處理邏輯的阻塞問題,畢竟Android的Service也是會阻塞的。
復制代碼 代碼如下:
public abstract class IntentService extends Service {
private volatile Looper mServiceLooper;
private volatile ServiceHandler mServiceHandler; //一個Handler封裝了Looper對象
private String mName;
private boolean mRedelivery;
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);
}
}
public IntentService(String name) { //構(gòu)造方法,需要提供一個name作為標識
super();
mName = name;
}
對于下面的setIntentRedelivery的參數(shù),如果為真時
復制代碼 代碼如下:
onStartCommand(Intent, int, int)} will return
Service#START_REDELIVER_INTENT}, so if this process dies before
onHandleIntent(Intent)} returns, the process will be restarted
如果為假時
復制代碼 代碼如下:
onStartCommand(Intent, int, int)} will return
Service#START_NOT_STICKY}, and if the process dies
public void setIntentRedelivery(boolean enabled) {
mRedelivery = enabled;
}
@Override
public void onCreate() { //這里重寫父類Service的創(chuàng)建,主要是構(gòu)造一個線程
super.onCreate();
HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
thread.start();
mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);
}
@Override
public void onStart(Intent intent, int startId) { //Android 2.0以前的Service啟動參數(shù)控制
Message msg = mServiceHandler.obtainMessage();
msg.arg1 = startId;
msg.obj = intent;
mServiceHandler.sendMessage(msg);
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) { //Android 2.0以后的服務啟動參數(shù)
onStart(intent, startId);
return mRedelivery ? START_REDELIVER_INTENT : START_NOT_STICKY;
}
@Override
public void onDestroy() { //服務摧毀的時候Looper一定要釋放掉,這點很重要。
mServiceLooper.quit();
}
@Override
public IBinder onBind(Intent intent) {
return null;
}
protected abstract void onHandleIntent(Intent intent);
}
從上面的代碼相信大家可以看出IntentService和Service的不同了,通過Looper和Thread來解決標準Service中處理邏輯的阻塞問題,畢竟Android的Service也是會阻塞的。
相關(guān)文章
Android 7.0系統(tǒng)webview 顯示https頁面空白處理方法
今天小編就為大家分享一篇Android 7.0系統(tǒng)webview 顯示https頁面空白處理方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
Android自定義SeekBar實現(xiàn)視頻播放進度條
這篇文章主要為大家詳細介紹了Android自定義SeekBar實現(xiàn)視頻播放進度條的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
Android實現(xiàn)文字動態(tài)高亮讀取進度效果
這篇文章主要為大家詳細介紹了Android實現(xiàn)文字動態(tài)高亮讀取進度效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05
Android向Excel寫入數(shù)據(jù)導出U盤并發(fā)送郵件
這篇文章主要為大家詳細介紹了Android將數(shù)據(jù)寫入Excel格式導出U盤、發(fā)送郵件,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07
android教程之使用asynctask在后臺運行耗時任務
AsyncTask用在需要在ui線程中調(diào)用、在背景線程中執(zhí)行耗時任務、并且在ui線程中返回結(jié)果的場合。下面就是一個在背景中運行的AsyncTask的實現(xiàn)DownloadDBTask2014-02-02

