IntentService源码分析

特殊的服务,继承服务并且是抽象类,底层使用了线程,用于后台任务执行并且执行完成之后会自动停止


 IntentService受限于Android 8.0(API级别26)施加的所有后台执行限制在大多数情况下,最好使用JobIntentService

构造函数

IntentService(String name)//名称命名工作线程

生命周期方法

的onCreate()//第一次启动时调用
onStart(Intent intent,int startId)
onStartCommand(Intent intent,int flags,int startId)//处理后台任务intent 
onBind(Intent intent)
的onDestroy()//服务停止

优点

  •  handlerThread异步的,执行后台耗时任务,任务完成会自动停止服务 
  • 是一个服务,优先级高于一般的线程,不会轻易的被系统杀死
  • 可以处理多个任务,不过要一个接一个的执行(的的AsyncTask只能执行一个任务,另起任务需要重新新)
  • 源码上看比的的AsyncTask简单
  • 由于处理程序中的弯针是顺序处理消息,所以多个任务也是按发起顺序排队处理

重要方法

//最重要的方法
//调用worker线程来处理工作,每次只处理一个intent,如果有多个,它会顺序处理,
//直到最后一个处理完毕,然后关闭自己
//此方法可能需要几秒钟才能完成,因此只能从工作线程调用
//需要子类覆写该方法,实现自己的任务代码
@WorkerThread
protected abstract void onHandleIntent(Intent var1)

//设置true,onHandleIntent返回前进程死亡,该进程会重新启动并执行最近的任务
public void setIntentRedelivery(boolean enabled)

继承IntenterService,

继承IntenterService,在AndroidManifest.xml中注册,通过startService(Intent)方法来调用,每执行一个后台任务就必须启动一次intentservice,所以多个任务就必须多次执行startService(inten 方法。

//启动多个任务
Intent internService = new Intent(this, MyService.class);
        internService.putExtra("chris_task", "task_1");
        startService(internService);
        internService.putExtra("chris_task", "task_2");
        startService(internService);
        internService.putExtra("chris_task", "task_3");
        startService(internService);
//任务执行,internService子类覆写onHandleIntent方法
 @Override
    protected void onHandleIntent(Intent intent) {
        String action = intent.getStringExtra("启动时候的key");
        switch (action){
            case "启动添加的task_name":
                //耗时任务执行
                
                break;
        }

    }


源码分析

路径

源码分析IntenterService机制

onCreate()
//创建HandlerThread 线程
HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
//获取该线程的looper
 mServiceLooper = thread.getLooper();
//用looper构造Handler的对象mServiceHandler
mServiceHandler = new ServiceHandler(mServiceLooper);
onStartCommand(Intent intent, int flags, int startId)
//调用了onStart方法
 onStart(intent, startId);
//onStartCommand返回值
return mRedelivery ? START_REDELIVER_INTENT : START_NOT_STICKY;
START_REDELIVER_INTENT :
//如果此进程在onHandleIntent(Intent)返回之前死亡 ,
//则该进程将重新启动并且意图重新递送。如果发送了多个意图,则只保证最近的意向重新发送。
START_NOT_STICKY:
//如果进程死亡,则Intent会与它一起死亡。

注意:mRedelivery默认值为false 即默认返回START_NOT_STICKY,要返回START_REDELIVER_INTENTd
调用setIntentRedelivery(boolean enabled)方法
onStart(Intent intent, int startId)
//该方法将intent startId放在message中,再将message发送给handler处理
msg.arg1 = startId;
msg.obj = intent;
mServiceHandler.sendMessage(msg);
这样通过Handler(mServiceHandler)发送消息最终都会在HandlerThread中执行
handleMessage(Message msg) 
onHandleIntent((Intent)msg.obj)
//通过ServiceHandler源码发现该handler的handleMessage中调用了onHandleIntent((Intent)msg.obj);
//并将外部传进来的intent作为参数
stopSelf(msg.arg1);
//停止服务,停止前会根据startId判断任务是否执行完毕,完了则立刻关闭服务否则不关闭,具体实现如下
 public final void stopSelf(int startId) {
        if (mActivityManager == null) {
            return;
        }
        try {
            mActivityManager.stopServiceToken(
                    new ComponentName(this, mClassName), mToken, startId);
        } catch (RemoteException ex) {
        }
    }
//需要在子类中实现,具体任务在该方法中实现
protected abstract void onHandleIntent(Intent intent)
onDestroy() //服务停止
mServiceLooper.quit();//退出looper

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值