关于Service中的耗时操作


        由于Service和Broadcast一样,都运行在主线程中,所以在这两个里面我们无法做一些长时间的耗时操作,也就是说,如果我们有一个后台服务,是每隔一段时间请求一次服务器,类似于心跳服务,只是没有心跳服务那么频繁,例如每2个小时执行一次连接服务器操作,这样的话,我们的应用可能已经退出了,而我们仍需要这个服务时开启的,这种情况,我们第一反应是让Service运行在一个独立的进程中,这一点是可以做到的,那么接下来就是对一些联网操作了,这是一个耗时操作。

        这种需求我们一般的做法是在Service中开启一个异步线程AsyncTask,然后再AsyncTask执行完毕后,将结果返回给Service中,但是,如果我们需要每隔一个小时就执行一次AsyncTask呢?这时候,我们不能在Service的主线程中执行Sleep操作,一种做法是通过监听时钟,每隔一分钟接收一次消息,当计数到60的时候,就执行一次AsyncTask。网络上还有一种做法是让Service去实现Runanble接口,等于是让自身是一个独立的线程,每次调用的时候是直接调用自身,从而不用创建新的AsyncTask。

        现在我的做法是采用另一种方式,整体思路也是一致的。

        在Android中有一个IntentServie,这个Service只启动一次,而且执行的onHandlerIntent方法是在一个独立的线程中执行,执行完毕后,这个Service就会被销毁。初看这个思路,感觉这样做的话,Service无法长时间运行,因为执行完就销毁,那么怎么去考虑每隔一个小时就唤醒呢?我的思路是:重写一个IntentService,仿效系统的IntentService,只是让线程执行完毕的时候,不再销毁这个Service,那么这样这个Service就能够长时间运行下去,同时不用独立创建AsyncTask和Runable了,同时可以直接在onHandleIntent中执行一些长时间的联网操作了。

       我们先看一下这个IntentService的代码:

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. package com.example.service;  
  2.   
  3. import android.app.Service;  
  4. import android.content.Intent;  
  5. import android.os.Handler;  
  6. import android.os.HandlerThread;  
  7. import android.os.IBinder;  
  8. import android.os.Looper;  
  9. import android.os.Message;  
  10.   
  11. public abstract class TestIntentService extends Service {  
  12.   
  13.     private volatile Looper mServiceLooper;  
  14.     private volatile ServiceHandler mServiceHandler;  
  15.     private String mName;  
  16.       
  17.     private final class ServiceHandler extends Handler{  
  18.         public ServiceHandler(Looper looper){  
  19.             super(looper);  
  20.         }  
  21.   
  22.         @Override  
  23.         public void handleMessage(Message msg) {  
  24.             super.handleMessage(msg);  
  25.             <span style="color:#FF0000;">onHandleIntent((Intent)msg.obj);</span>  
  26.         }  
  27.     }  
  28.       
  29.     public TestIntentService(String name){  
  30.         super();  
  31.         mName = name;  
  32.     }  
  33.       
  34.     @Override  
  35.     public void onCreate() {  
  36.         super.onCreate();  
  37.         HandlerThread thread = new HandlerThread("IntentService["+mName+"]");  
  38.         thread.start();  
  39.         mServiceLooper= thread.getLooper();  
  40.         mServiceHandler = new ServiceHandler(mServiceLooper);  
  41.     }  
  42.     @Override  
  43.     @Deprecated  
  44.     public void onStart(Intent intent, int startId) {  
  45.         super.onStart(intent, startId);  
  46.         Message msg = mServiceHandler.obtainMessage();  
  47.         msg.arg1 = startId;  
  48.         msg.obj = intent;  
  49.         mServiceHandler.sendMessage(msg);  
  50.     }  
  51.       
  52.     protected abstract void onHandleIntent(Intent intent);  
  53.     @Override  
  54.     public IBinder onBind(Intent arg0) {  
  55.         return null;  
  56.     }  
  57.     @Override  
  58.     public void onDestroy() {  
  59.     }  
  60.       
  61.       
  62.   
  63. }  


整体思路是这样的,其他的实现就和网上的大部分内容一致了,接下来就是整个小的测试项目了。

http://pan.baidu.com/s/1dDsv3Vj


  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值