IntentService的原理及使用

在Android开发中,我们或许会碰到这么一种业务需求,一项任务分成几个子任务,子任务按顺序先后执行,子任务全部执行完后,这项任务才算成功。那么,利用几个子线程顺序执行是可以达到这个目的的,但是每个线程必须去手动控制,而且得在一个子线程执行完后,再开启另一个子线程。或者,全部放到一个线程中让其顺序执行。这样都可以做到,但是,如果这是一个后台任务,就得放到Service里面,由于Service和Ac

大家好,又见面了,我是你们的朋友全栈君。

在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

[java] 
view plain
copy

  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.   
  15.     @Override  
  16.     public void onCreate() {  
  17.         System.out.println(“onCreate”);  
  18.         super.onCreate();  
  19.     }  
  20.   
  21.     @Override  
  22.     public void onStart(Intent intent, int startId) {  
  23.         System.out.println(“onStart”);  
  24.         super.onStart(intent, startId);  
  25.     }  
  26.   
  27.   
  28.     @Override  
  29.     public int onStartCommand(Intent intent, int flags, int startId) {  
  30.         System.out.println(“onStartCommand”);  
  31.         return super.onStartCommand(intent, flags, startId);  
  32.     }  
  33.   
  34.   
  35.     @Override  
  36.     public void setIntentRedelivery(boolean enabled) {  
  37.         super.setIntentRedelivery(enabled);  
  38.         System.out.println(“setIntentRedelivery”);  
  39.     }  
  40.   
  41.     @Override  
  42.     protected void onHandleIntent(Intent intent) {  
  43.         //Intent是从Activity发过来的,携带识别参数,根据参数不同执行不同的任务  
  44.         String action = intent.getExtras().getString(“param”);  
  45.         if (action.equals(“oper1”)) {  
  46.             System.out.println(“Operation1”);  
  47.         }else if (action.equals(“oper2”)) {  
  48.             System.out.println(“Operation2”);  
  49.         }  
  50.           
  51.         try {  
  52.             Thread.sleep(2000);  
  53.         } catch (InterruptedException e) {  
  54.             e.printStackTrace();  
  55.         }  
  56.     }  
  57.   
  58.     @Override  
  59.     public void onDestroy() {  
  60.         System.out.println(“onDestroy”);  
  61.         super.onDestroy();  
  62.     }  
  63.   
  64. }  



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

[java] 
view plain
copy

  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,一定要配置,否则是不起作用的,开始我就是忘了,结果半天没反应。

[html] 
view plain
copy

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



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

IntentService的原理及使用

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


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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/126273.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Pytest(8)parametrize参数化「建议收藏」

    Pytest(8)parametrize参数化「建议收藏」前言当某个接口中的一个字段,里面规定的范围为1-5,你5个数字都要单独写一条测试用例,就太麻烦了,这个时候可以使用pytest.mark.parametrize装饰器可以实现测试用例参数化。官方示

  • PHP审计之WeEngine审计

    PHP审计之WeEngine审计前言审计该CMS加深一下对于MVC架构的php审计流程梳理路由打开代码看到index.php文件if($_W['os']=='mo

    2021年12月13日
  • 用thinkphp开启伪静态,用wamp开启很快搞定;但是用phpstudy总是开启失败,为什么?…

    用thinkphp开启伪静态,用wamp开启很快搞定;但是用phpstudy总是开启失败,为什么?…

    2021年10月15日
  • 如何学分子模拟的软件

    如何学分子模拟的软件当今分子模拟已经成为很多领域学术研究的主流方法。多年前,因为计算量的原因,很多情况下,MC方法是首选,特别是只关心平衡体系,关心相边界行为的时候。随着计算资源的增加、计算成本的降低、一些研究对象的平衡态的体系已经几乎被做烂了,科研工作者慢慢关心动力学行为,非平衡特征,致力于发现新的现象,新的物理规律(总要有事做,有饭吃吧),于是MD越来越普及,用的人也越来越多。除了极端的方法学工作者,一般情况下…

  • webstorm快捷键大全

    webstorm快捷键大全  

  • 2020最新版Net加壳工具

    2020最新版Net加壳工具VirboxProtector发布最新版本Net加壳工具:VirboxProtector2.VirboxProtector为.NETFramework编写的软件做代码保护,防止代码被反编译,防止IL代码在内存被Dump。同时可配合授权产品实现软件的许可管理。加密技术VirboxProtector.NET版通过多种保护方式来防止反编译,加密后可让任何现有工具都无法反编译。JIT加密将.NET所有方法的IL指令经过加密,仅在.NET虚拟机进行J.

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号