转载自:http://blog.csdn.net/ryantang03/article/details/8146154

在Android开发中,我 们或许会碰到这么一种业务需求,一项任务分成几个子任务,子任务按顺序先后执行,子任务全部执行完后,这项任务才算成功。那么,利用几个子线程顺序执行是 可以达到这个目的的,但是每个线程必须去手动控制,而且得在一个子线程执行完后,再开启另一个子线程。或者,全部放到一个线程中让其顺序执行。这样都可以 做到,但是,如果这是一个后台任务,就得放到Service里面,由于Service和Activity是同级的,所以,要执行耗时任务,就得在 Service里面开子线程来执行。那么,有没有一种简单的方法来处理这个过程呢,答案就是IntentService。

什么是IntentService,首先看看官方的解释:

IntentService is a base class forServices that handle asynchronous
requests (expressed asIntents) on demand. Clients send requests throughstartService(Intent)
calls; the service is started as needed, handles each Intent in turn
using a worker thread, and stops itself when it runs out of work

简单
说,IntentService是继承于Service并处理异步请求的一个类,在IntentService内有一个工作线程来处理耗时操作,启动
IntentService的方式和启动传统Service一样,同时,当任务执行完后,IntentService会自动停止,而不需要我们去手动控
制。另外,可以启动IntentService多次,而每一个耗时操作会以工作队列的方式在IntentService的onHandleIntent回
调方法中执行,并且,每次只会执行一个工作线程,执行完第一个再执行第二个,以此类推。

还有一个说明是:

All
requests are handled on a single worker thread -- they may take as long
as necessary (and will not block the application's main loop), but only
one request will be processed at a time.

大致意思是:所有请求都在一个单线程中,不会阻塞应用程序的主线程(UI Thread),同一时间只处理一个请求。

那么,用IntentService有什么好处呢?首先,我们省去了在Service中手动开线程的麻烦,第二,当操作完成时,我们不用手动停止Service,第三,it's so easy to use!

ok,接下来让我们来看看如何使用,我写了一个Demo来模拟两个耗时操作,Operation1与Operation2,先执行1,2必须等1执行完才能执行:

新建工程,新建一个继承IntentService的类,我这里是IntentServiceDemo.java

  1. public class IntentServiceDemo extends IntentService {
  2.  
  3. public IntentServiceDemo() {
  4. //必须实现父类的构造方法
  5. super("IntentServiceDemo");
  6. }
  7.  
  8. @Override
  9. public IBinder onBind(Intent intent) {
  10. System.out.println("onBind");
  11. return super.onBind(intent);
  12. }
  13.  
  14. @Override
  15. public void onCreate() {
  16. System.out.println("onCreate");
  17. super.onCreate();
  18. }
  19.  
  20. @Override
  21. public void onStart(Intent intent, int startId) {
  22. System.out.println("onStart");
  23. super.onStart(intent, startId);
  24. }
  25.  
  26. @Override
  27. public int onStartCommand(Intent intent, int flags, int startId) {
  28. System.out.println("onStartCommand");
  29. return super.onStartCommand(intent, flags, startId);
  30. }
  31.  
  32. @Override
  33. public void setIntentRedelivery(boolean enabled) {
  34. super.setIntentRedelivery(enabled);
  35. System.out.println("setIntentRedelivery");
  36. }
  37.  
  38. @Override
  39. protected void onHandleIntent(Intent intent) {
  40. //Intent是从Activity发过来的,携带识别参数,根据参数不同执行不同的任务
  41. String action = intent.getExtras().getString("param");
  42. if (action.equals("oper1")) {
  43. System.out.println("Operation1");
  44. }else if (action.equals("oper2")) {
  45. System.out.println("Operation2");
  46. }
  47.  
  48. try {
  49. Thread.sleep(2000);
  50. } catch (InterruptedException e) {
  51. e.printStackTrace();
  52. }
  53. }
  54.  
  55. @Override
  56. public void onDestroy() {
  57. System.out.println("onDestroy");
  58. super.onDestroy();
  59. }
  60.  
  61. }

我把生命周期方法全打印出来了,待会我们来看看它执行的过程是怎样的。接下来是Activity,在Activity中来启动IntentService:

  1. public class TestActivity extends Activity {
  2. /** Called when the activity is first created. */
  3. @Override
  4. public void onCreate(Bundle savedInstanceState) {
  5. super.onCreate(savedInstanceState);
  6. setContentView(R.layout.main);
  7.  
  8. //可以启动多次,每启动一次,就会新建一个work thread,但IntentService的实例始终只有一个
  9. //Operation 1
  10. Intent startServiceIntent = new Intent("com.test.intentservice");
  11. Bundle bundle = new Bundle();
  12. bundle.putString("param", "oper1");
  13. startServiceIntent.putExtras(bundle);
  14. startService(startServiceIntent);
  15.  
  16. //Operation 2
  17. Intent startServiceIntent2 = new Intent("com.test.intentservice");
  18. Bundle bundle2 = new Bundle();
  19. bundle2.putString("param", "oper2");
  20. startServiceIntent2.putExtras(bundle2);
  21. startService(startServiceIntent2);
  22. }
  23. }

最后,别忘了配置Service,因为它继承于Service,所以,它还是一个Service,一定要配置,否则是不起作用的,开始我就是忘了,结果半天没反应。

  1. <service android:name=".IntentServiceDemo">
  2. <intent-filter >
  3. <action android:name="com.test.intentservice"/>
  4. </intent-filter>
  5. </service>

ok,最后来看看执行结果:

从结果可以看
到,onCreate方法只执行了一次,而onStartCommand和onStart方法执行了两次,开启了两个Work
Thread,这就证实了之前所说的,启动多次,但IntentService的实例只有一个,这跟传统的Service是一样的。Operation1
也是先于Operation2打印,并且我让两个操作间停顿了2s,最后是onDestroy销毁了IntentService。

这就是IntentService,一个方便我们处理业务流程的类,它是一个Service,但是比Service更智能。

[Android Pro] Android中IntentService的原理及使用的更多相关文章

  1. Android中IntentService的原理及使用

    在Android开发中,我们或许会碰到这么一种业务需求,一项任务分成几个子任务,子任务按顺序先后执行,子任务全部执行完后,这项任务才算成功.那么,利用几个子线程顺序执行是可以达到这个目的的,但是每个线 ...

  2. Android 7.0 中 ContentProvider 实现原理

    欢迎大家前往腾讯云社区,获取更多腾讯海量技术实践干货哦~ 作者:汪毅雄 导语: 本文描述了ContentProvider发布者和调用者这两在Framework层是如何实现的. 作为Android的四大 ...

  3. [Android Pro] android中permission_group与permisson区别、作用

    转载:http://blog.csdn.net/feng88724/article/details/6409313 其实Android在定义 permission 时, 为每个Permission都进 ...

  4. [Android Pro] service中显示一个dialog 或者通过windowmanage显示view

    转载: http://blog.csdn.net/huxueyan521/article/details/8954844 通过windowmananger来在窗口上添加view的时候,需要设置aler ...

  5. [Android Pro] Android 4.1 使用 Accessibility实现免Root自动批量安装功能

    reference to  :  http://www.infoq.com/cn/articles/android-accessibility-installing?utm_campaign=info ...

  6. [Android Pro] Android 4.3 NotificationListenerService使用详解

    reference to : http://blog.csdn.net/yihongyuelan/article/details/40977323 概况 Android在4.3的版本中(即API 18 ...

  7. [Android Pro] android root权限破解分析

    许 多机友新购来的Android机器没有破解过Root权限,无法使用一些需要高权限的软件,以及进行一些高权限的操作,其实破解手机Root权限是比较简 单及安全的,破解Root权限的原理就是在手机的/s ...

  8. [Android Pro] Android 手机root 并 安装 BusyBox pro 和 Android Terminal Emulator

    Android root 工具:http://www.z4root.cn/yijianrootshouji/ 推荐的是:root精灵手机版 BusyBox 称为 Linux 工具里的瑞士军刀.简单的说 ...

  9. [Android Pro] Android开发实践:自定义ViewGroup的onLayout()分析

    reference to : http://www.linuxidc.com/Linux/2014-12/110165.htm 前一篇文章主要讲了自定义View为什么要重载onMeasure()方法( ...

随机推荐

  1. 实现nlp文本生成中的beam search解码器

    自然语言处理任务,比如caption generation(图片描述文本生成).机器翻译中,都需要进行词或者字符序列的生成.常见于seq2seq模型或者RNNLM模型中. 这篇博文主要介绍文本生成解码 ...

  2. USACO 5.5 Hidden Password

    Hidden Password ACM South Eastern Europe -- 2003 Sometimes the programmers have very strange ways of ...

  3. (转)python随机数用法

    进行以下操作前先 import random ,导入random模块 1. random.seed(int) 给随机数对象一个种子值,用于产生随机序列. 对于同一个种子值的输入,之后产生的随机数序列也 ...

  4. Request常用方法(转)

    原文地址:http://www.lihuai.net/program/python/1617.html Python Requests库:HTTP for Humans 时间: 2014/12/30 ...

  5. JAVAEE——SSH项目实战04:联系人添加、列表显示和修改

    作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7159337.html 一.联系人添加 1.添加页面设计    linkman/list. ...

  6. android manifest.xml 文件

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 清单文件 包括 包名 应用 各个组件  四大组件 使用到的权限 应用程序所需要的最低安卓 ...

  7. [BZOJ3779]重组病毒(LCT+DFS序线段树)

    同[BZOJ4817]树点涂色,只是多了换根操作,分类讨论下即可. #include<cstdio> #include<algorithm> #define lc ch[x][ ...

  8. [BZOJ4570][SCOI2016]妖怪(凸包)

    两种做法,前一种会TLE. 第一种是高一数学题做法,设一个妖怪的atk和dnf分别为x和y,则它在(a,b)环境下的战斗力为x+y/a*b+y+x/a*b. 设t为b/a,则战斗力即$f(x,y,t) ...

  9. (Nginx和PHP下)URL重写,TP实现URL重写

    UrlRewrite就是我们通常说的地址重写,用户得到的全部都是经过处理后的URL地址. 优点 一:提高安全性,可以有效的避免一些参数名.ID等完全暴露在用户面前,如果用户随便乱输的话,不符合规则的话 ...

  10. CDOJ 1401 谭爷的黑暗沙拉 数学

    谭爷的黑暗沙拉 题目连接: http://mozhu.today/#/problem/show/1401 Description 谭爷有\(n\)种不同种类的食材(水果&蔬菜),他想做出一份总 ...