Android ApiDemos示例解析(44)

App->Service->Service Start Arguments Controller

本例是ApiDemos关于Service的最后一个例子,这个例子的主要目的是介绍如何向Service传递参数。前面的例子忽略了一个重要的问题: Service 的onStartCommand 或是 onStart(2.1版本之前)是使用调用它的Android组件(通常是Activity)同一个Thread来执行的,对应Activity来说,这个Thread通常是UI Thread,前面的Service例子都是提供非常简单的服务,对于UI 性能不会有很大影响,但如果在Service中使用了较费时的操作,如果网络访问,数据库查询,如果还是使用UI Thread来运行的话,就可能大大降低UI的响应性能,甚至出现ANR(Application Not Response)对话框,所以通常都是在Service新建一个线程来处理来自Client的请求。

Android.os 的Handler, HandlerThread, Loop, Message 常用于Service中,其中Handler介绍可以参见Android 系统Handler用法简介。

Android 中每个Thread都可以有一Message Queue,但除UI Thread外,Thread缺省情况下不带Message Queue, 要为一个Thread 创建一个Message Queue,可以参见下面代码:

class LooperThread extends Thread {
 public Handler mHandler;
 public void run() {
 Looper.prepare();
 mHandler = new Handler() {
 public void handleMessage(Message msg) {
 // process incoming messages here
 }
 };
 Looper.loop();
 }
 }

Looper.prepare()用来创建一个Message Queue, Looper.loop() 处理消息直到Loop停止。 在Thread在创建的Handler将会和Thread的Message Queue关联。Handler的handleMessage用来处理消息,其类型为Message类。

HandlerThread派生于Thread,用于方便创建一个带Looper的Thread。本例就是使用了HandlerThread.

private volatile Looper mServiceLooper;
private volatile ServiceHandler mServiceHandler;     

private final class ServiceHandler extends Handler {
public ServiceHandler(Looper looper) {
 super(looper);
}     

@Override
public void handleMessage(Message msg) {
 ...
 }     

 ...
 HandlerThread thread = new HandlerThread("ServiceStartArguments",
 Process.THREAD_PRIORITY_BACKGROUND);
thread.start();     

mServiceLooper = thread.getLooper();
mServiceHandler = new ServiceHandler(mServiceLooper);

ServiceStartArguments Service 使用一个新创建的Thread来处理来自Client的消息,这个Thread不是UI Thread,使用HandlerThread 创建一个带Looper的线程,而具体的消息处理是由ServiceHandler的handleMessage来处理。

Message类定义了消息,可以含有对消息的描述description,类型what,缺省带arg1,arg2, obj三个参数可以直接使用。 并提供了obtain()静态函数来构造一个新的Message对象。

ServiceStartArguments.Controller 为ServiceStartArguments Service的Client。它定义了四个按钮,通过Intent的Extra向Service传递参数:

startService(new Intent(Controller.this,
 ServiceStartArguments.class)
 .putExtra("name", "One"));     

startService(new Intent(Controller.this,
 ServiceStartArguments.class)
 .putExtra("name", "Two"));

startService(new Intent(Controller.this,
 ServiceStartArguments.class)
 .putExtra("name", "Three")
 .putExtra("redeliver", true));

startService(new Intent(Controller.this,
 ServiceStartArguments.class)
 .putExtra("name", "Failure")
 .putExtra("fail", true));

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索final、volatile
, thread
, service
, handler
, handlemessage
, message
, 一个
, Looper
, looper.prepare
, looper.loop
, service与thread区别
handlerthread
apidemos、android apidemos、api demos、apidemos下载、android api demos,以便于您获取更多的相关知识。

时间: 2024-09-27 22:19:55

Android ApiDemos示例解析(44)的相关文章

Android ApiDemos示例解析(43):App->Service->Remote Service Controller

Remote Service Controller 和使用Local Service的Android ApiDemo示例解析(40):App->Service->Local Service Controller 都是使用Service的"Started" 模式,RemoteService在 AndroidManifest.xml中的定义如下: <service android:name=".app.RemoteService" android:pr

Android ApiDemos示例解析(37):App-&amp;gt;Search-&amp;gt;Query Search Results

这个例子单独运行时(从Launcher启动),这时接受到的Intent不含ACTION_SEARCH,和一个普通的Activity没有什么两样. 在例(36)时,它是作为查询处理Activity用于显示用户查询内容. SearchQueryResults 在AndroidManifest.xml定义为 Searchable Activity: <intent-filter> <action android:name="android.intent.action.SEARCH&q

Android ApiDemos示例解析(35):App-&amp;gt;Preferences-&amp;gt;Advanced preferences

前篇文章Android ApiDemo示例解析(31):App->Preferences->Launching preferences 中用到了Advanced preferences 中定义的AdvancedPreferences. 本篇具体介绍AdvancedPreferences, 这个例子称为Advanced ,是因为 它涉及到了自定义Preference, 并在一个工作线程中刷新某个Preference的值. Preference 为显示在 PreferenceActivity (一

Android ApiDemos示例解析(30) App-&amp;gt;Preferences-&amp;gt;Preferences from XML

我们在前面的例子Android ApiDemo示例解析(9):App->Activity->Persistent State 介绍了可以使用Shared Preferences来存储一些状态,Shared Preferences更一般的用法是用来存储一些应用程序偏好(设置). 包 android.preference 提供了很多类可以方便应用程序来显示和设置应用相关的偏好.当然你可以使用自定义的UI来配置这些程 序偏好.但使用android.preference中定义的类可以给用户一个统一的U

Android ApiDemos示例解析(14) App-&amp;gt;Activity-&amp;gt;Save &amp;amp; Restore State

Save & Restore State与之前的例子Android ApiDemo示例解析(9):App->Activity->Persistent State 实现的 UI类似,但功能和实现方法稍有不同.(9)是通过Shared Preferences 和 Activity 的onPause() ,和onResume()来保持UI中 EditText 的值.本例是通过onSaveInstanceState(Bundle savedBundle) 来实现保持UI状态. 和onPause

Android ApiDemos示例解析(25) App-&amp;gt;Menu-&amp;gt;Inflate from XML

本例演示了如何从Menu 资源(XML 定义)展开菜单项.这个例子的onCreate 采用了使用代码来创建Activity 界面的方法 而通常的方法是采用Layout资源的方法.如果你有兴趣了解一下如何使用代码创建UI,可以参考本例的onCreate方法,但这不是 本例的演示目的. 使用XML 菜单资源来展开菜单的一般步骤是 1. 在/res/menu目录下定义菜单资源,本例中定义 了10种不同风格的菜单项:"Title only", "Title and Icon"

Android ApiDemos示例解析(22) App-&amp;gt;Dialog

这个例子的主Activity定义在AlertDialogSamples.java 主要用来介绍类AlertDialog的用法,AlertDialog提供的功能是多 样的: 显示消息给用户,并可提供一到三个按钮(OK, Cancel ,Yes ,No)用于选择或是显示警告. 显示一个列表 以供用户选择,列表中可以是Radio Button  (单选),Check button (多选) 显示文本框来接受用户输入等. 创建AlertDialog一般是通过AlertDialog.Builder来构造:

Android ApiDemos示例解析(21) App-&amp;gt;Device Admin

Device Admin示例介绍了类DeviceAdminReceiver,DevicePolicyManager和ActivityManager. 类 DevicePolicyManager 用于管理Android设备定义的一些策略,主要指密码定义的长度,密码是否要含大写字母,小写字母等设 置密码需要满足的规范,锁定设备或是清除所有用户数据,这个类一般需要配合DeviceAdminReceiver来使用. DeviceAdminReceiver派生于BroadcastReceiver,可以接受

Android ApiDemos示例解析(17) App-&amp;gt;Activity-&amp;gt;Translucent Blur

这个例子和Translucent不同的一点是Blur,也就是显示在当前Activit背后的其它Activity以模糊方式显示. 这是通 过window对象Flag来设置的. getWindow().setFlags(WindowManager.LayoutParams.FLAG_BLUR_BEHIND, WindowManager.LayoutParams.FLAG_BLUR_BEHIND); 其它设置Theme和Translucent示例一样. 以上是小编为您精心准备的的内容,在的博客.问答.