android IntentService實現(xiàn)原理及內部代碼分享
更新時間:2013年06月02日 15:23:43 作者:
android IntentService實現(xiàn)原理及內部代碼分享,需要的朋友可以參考一下
很多網(wǎng)友可能發(fā)現(xiàn)Android中除了Service還有一個IntentService,他們之間到底有哪些區(qū)別呢? 在繼承關系上而言IntentService是Service的子類,內部實現(xiàn)的代碼中涉及到一些Android入門開發(fā)者不了解的Looper,Android123在早期的文章中已經(jīng)說明他們的用法,這里不再贅述,有關原理大家可以看源碼實現(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) { //構造方法,需要提供一個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)建,主要是構造一個線程
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) { //構造方法,需要提供一個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)建,主要是構造一個線程
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也是會阻塞的。
相關文章
android使用url connection示例(get和post數(shù)據(jù)獲取返回數(shù)據(jù))
這篇文章主要介紹了android使用URLConnection來get和post數(shù)據(jù)獲取返回的數(shù)據(jù),大家參考使用吧2014-01-01Android中ActionBar以及menu的代碼設置樣式
這篇文章主要介紹了Android中ActionBar以及menu的代碼設置樣式的相關資料,需要的朋友可以參考下2015-07-07Android開發(fā)之圖片壓縮實現(xiàn)方法分析
這篇文章主要介紹了Android開發(fā)之圖片壓縮實現(xiàn)方法,結合實例形式分析了Android圖片壓縮的原理、實現(xiàn)方法及相關操作注意事項,需要的朋友可以參考下2019-03-03android studio按鈕監(jiān)聽的5種方法實例詳解
這篇文章主要介紹了android studio按鈕監(jiān)聽的5種方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03Android中Xposed框架篇---修改系統(tǒng)位置信息實現(xiàn)自身隱藏功能實例
本篇文章介紹了Android中Xposed框架的使用,詳細的介紹了修改系統(tǒng)位置信息實現(xiàn)自身隱藏功能實例,有需要的朋友可以了解一下。2016-11-11Android開發(fā)之PopupWindow實現(xiàn)彈窗效果
這篇文章主要為大家詳細介紹了Android開發(fā)之PopupWindow實現(xiàn)彈窗效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-09-09