初步概括Android Service 功能 |
本文标签:Android Service 本文向大家介绍Android Service ,可能好多人还不了解Android Service的服务的种种特性,没有关系,看完本文你肯定有不少收获,掌握了Android Service 这们服务会使我们的编程工作更简单和更轻松 。 常见的例子:media player 从播放列表播放音乐,播放器有一些activities来叫用户选定歌曲并开始播放 。但是,播放本身不需要activity处理,因为用户希望关闭activity后歌曲会继续播放 。 因此media player 的activity 会启动一个service 。当用户离开窗体后,系统还可以保持歌曲的播放 。可以与正在运行的service通信或者启动一个service 。与service通信依赖于service公开的接口 。例如音乐播放,接口可能允许用户暂停、启动、停止、继续播放列表 。 象activities和其他组件一样,Android Service 运行在应用程序的主线程 。因此他们不会阻塞其他的组件或者用户界面 。可以在服务中启用另外的线程来做耗时的工作,如音乐播放 。请参见Processes and Threads. Broadcast receivers 程序可以有任意数量的broadcast receivers 来相应它觉得重要的通知 。所有的receivers 继承自 BroadcastReceiver 类 。Broadcast receivers 不会显示用户界面,但是他们可能启动一个activity 来相应收到的通知 。 或者使用 NotificationManager 通知用户 。 可以通过多种方式通知用户-开启背景灯、振动设备、播放声音等 。最典型的是在状态栏显示一个图标,这样用户就可以点它打开看通知内容 。 Content providers 实现一组标准的方法,来使其他程序可以存取数据 。但是,程序并不是直接调用这些方法,而是使用ContentResolver 对象来调用这些方法 。ContentResolve的作用是管理provider和程序之间的多进程交互 。 请参见 Content Providers 文档 。 当ContentResolver 发起一个请求的时候Content providers 激活. 另外三个组件: — activities, services, 和 broadcast receivers — 被叫做intents的异步的消息激活 。intent 是一个保持了消息信息的 Intent 对象 。对于activities 和 services,它传送了被请求的数据和特定的URI 。 例如,它可能传达一个请求,叫activity来呈现一个图片或者叫用户编辑某段文本 。对于broadcast receivers,Internt对象传送了通知的动作 。例如,它可能通知相机的按钮被按下 。 |