編輯:關於Android編程
IntentService提供了在單個後台線程運行操作的簡單結構。這允許它操作耗時操作,而不影響UI響應。同樣,IntentService也不影響UI生命周期事件,所以,它在某些可能關閉AsyncTask的情況下,仍會繼續運行(實測在Activity的onDestory裡寫AsyncTask無法運行)。
IntentService有如下限制:
1.它不能直接影響UI。要把結果反映給UI,需要發給Activity
2.工作請求會順序運行。如果一個操作未結束,後面發送的操作必須等它結束(單線程)
3.IntentService裡運行的操作無法被中斷
然而,在大多數情況下,IntentService是簡單後台任務的首選方式。
本節展示了如何創建IntentService的子類,如何創建onHandleIntent()回調,如何在AndroidManifest.xml聲明IntentService。
創建IntentService
定義一個IntentService的子類,覆蓋onHandleIntent()方法:
復制代碼 代碼如下:
public class RSSPullService extends IntentService {
@Override
protected void onHandleIntent(Intent workIntent) {
// Gets data from the incoming Intent
String dataString = workIntent.getDataString();
...
// Do work here, based on the contents of dataString
...
}
}
提示:其他Service正常的回調,像 onStartCommand()在IntentService裡會自動調用。在IntentService裡,應該避免覆蓋這些回調。
在AndroidManifest.xml裡定義IntentService
IntentService也是Service),需要在AndroidManifest.xml裡注冊。
復制代碼 代碼如下:
<application
android:icon="@drawable/icon"
android:label="@string/app_name">
...
<!--
Because android:exported is set to "false",
the service is only available to this app.
-->
<service
android:name=".RSSPullService"
android:exported="false"/>
...
<application/>
android:name屬性指定了IntentService的類名。
注意:<service>節點不能包含intent filter。發送工作請求的Activity使用明確的Intent,會指定哪個IntentService。這也意味著,只有同一個app裡的組件,或者另一個有相同user id的應用才能訪問IntentService。
現在你有了基礎的IntentService類,可以用Intent對象發送工作請求。
創建發送工作請求傳給IntentService
創建一個明確的Intent,添加需要的數據,調用startService()發送給IntentService
復制代碼 代碼如下:/*
* Creates a new Intent to start the RSSPullService
* IntentService. Passes a URI in the
* Intent's "data" field.
*/
mServiceIntent = new Intent(getActivity(), RSSPullService.class);
mServiceIntent.setData(Uri.parse(dataUrl));
//Call startService()
// Starts the IntentService
getActivity().startService(mServiceIntent);
提示:可以在Activity or Fragment的任意位置發送工作請求。如果你需要先取到用戶輸入,你可以在點擊事件或類似手勢的回調方法裡發送工作請求。
一旦調用了startService(),IntentService會在onHandleIntent()工作,完了結束自身。
下一步是報告結果給原來的Activity或Fragment,下節講如何用BroadcastReceiver實現。請參考此文:http://www.jb51.net/article/51548.htm
SVG矢量圖在圖片表現力方面遠遠優於PNG位圖,同時在可維護性和修改性方面也比位圖要方便很多。盡管Android在5.0版本就引入了SVG圖片的解決方案:Vector。然
ActivityManager.RunningAppProcessInfo類與獲取正在運行的應用程序每一個應用程序都會運行在它獨立的進程裡,但是為了節省資源或者這些應用程
模式的定義 適配器模式把一個類的接口變換成客戶端所期待的另一種接口,從而使原本因接口不匹配而無法在一起工作的兩個類能夠在一起工作。 使用場景 用電源接口做例
最近在處理一些lowmemorykiller相關的問題,於是對lowmemorykiller機制作了一個簡單的了解。在這裡總結一下。首先,是lowmemorykiller