美文网首页android技术
Android service笔记

Android service笔记

作者: silencefun | 来源:发表于2019-03-13 16:57 被阅读0次

    这个真拖延太久了,必须把这个笔记完成。,,看了一下2016年的草稿,从Android 6.0 这都要10.0了。


    一、Service释义、作用、分类。

    Service是Android应用程序中的一个组件,与用户不进行交互,可以长期的执行在后台。
    分类:
    Android O 之前,创建前台服务的方式通常是先创建一个后台服务,然后将该服务推到前台。Android O及Android P,系统不允许后台应用创建后台服务,Android O 引入了一种全新的方法,即ContextCompat.startForegroundService() ,以在前台启动新服务。Service分为如下三类

    1.foreground service
    fg Service执行一些对于用户来说是可感知的操作,如audio应用使用fg service来播放歌曲。
    2.background service
    bg service执行的操作对用户而言是不可感知的。
    3.bound service
    bound service主要是提供c/s接口,允许组件与service进行通信,或者是跨进程的通信。
    这是由于启动方式的不同导致了三种service,

    startService -> background service.
    startForegroundService -> foreground service
    bindService -> bound service

    二、使用

    2.1声明

    Service是Android中的四大组件,使用它一定要在AndroidManifest.xml中声明,在AndroidManifest.xml中声明是为了让PackageManagerService能解析出该Service, 并建立对应的数据结构

     <service android:name=".myservice"
            android:enabled="true"
            android:exported="true"
            android:icon="@drawable/background_blue"
            android:label="string"
            android:process="string"
            android:permission="string">
     </service>
    

    说明:

        name:服务的路径
        enabled:表示系统是否能够实例化该组件
        exported:表示该服务是否能够被其他应用程序组件所调用或者交互
        android:process 是否需要在单独的进程中运行,当设置为android:process=”:remote”时,代表Service在单独的进程中运行。注意“:”很重要,它的意思是指要在当前进程名称前面附加上当前的包名,所以“remote”和”:remote”不是同一个意思,前者的进程名称为:remote,而后者的进程名称为:App-packageName:remote。
        android:isolatedProcess     设置 true 意味着,服务会在一个特殊的进程下运行,这个进程与系统其他进程分开且没有自己的权限。与其通信的唯一途径是通过服务的API(bind and start)。
    

    2.2启动

    1.startService()
    startService()开启服务时服务执行的生命周期方法是

    onCreate()----onStartCommand()-----onStop()----onDestory()
    

    其中onCreate()会在服务第一次创建的时候调用,当多次调用startService方法的时候,onCreate只会执行一次,而onStartCommand会执行多次,onDestroy方法会在服务销毁的时候进行调用
    服务的销毁 该方式下启动的服务可以调用stopService(Intent intent)或者stopSelf()来进行服务的销毁。
    2.bindService
    bindService绑定服务时服务执行的生命周期方法是

    onCreate()----onBind()-----onUnbind()----onStop()----onDestory()
    

    onCreate,onBind 会在bindService第一次调用的时候去执行,如果多次调用bindService,onCreate和onBind也就执行一次,onUnbind和onDestroy会在解绑服务的时候进行调用。
    服务的解绑 该方式下绑定的服务需要调用unbindService(ServiceConnection mConnection)方法来进行服务的解绑操作。
    绑定服务的最大作用就是用来实现对Service执行的任务进行进度监控。

    三、笔记

    3.1

    服务类似于其他应用程序的对象,运行在主线程中。这就意味着你如果在服务中进行耗时的操作,你需要开启一个子线程去处理这个操作,不然在服务中超过20秒未响应会发生ANR导致程序崩溃。IntentService的出现就是为了解决在服务中操作耗时任务的。

    3.2

    在Android中绑定式服务bindService会随着Activity的结束而结束,但是启动式服务startService不受Activity的影响。

    3.3service与线程的区别

    Thread 是程序执行的最小单元,它是分配CPU的基本单位,android系统中UI线程也是线程的一种,当然Thread还可以用于执行一些耗时异步的操作。

    Service是Android的一种机制,服务是运行在主线程上的,它是由系统进程托管。它与其他组件之间的通信类似于client和server,是一种轻量级的IPC通信,这种通信的载体是binder,它是在linux层交换信息的一种IPC,而所谓的Service后台任务只不过是指没有UI的组件罢了。
    二者没有任何关系

    3.3 显/隐式 启动

    //显示启动
    Intent intent = new Intent(this,ForegroundService.class);
    startService(intent);
    

    隐式启动:
    但是Android 5.0一出来后,其中有个特性就是Service Intent must be explitict,也就是说从Lollipop开始,service服务必须采用显示方式启动。 需要设置一个Action,我们可以把Action的名字设置成Service的全路径名字,在这种情况下android:exported默认为true。

    3.4兼容处理

    Android 8.0 还对特定函数做出了以下变更:

    • 如果针对 Android 8.0 的应用尝试在不允许其创建后台服务的情况下使用 startService() 函数,则该函数将引发一个 IllegalStateException。
    • 新的 Context.startForegroundService() 函数将启动一个前台服务。现在,即使应用在后台运行,系统也允许其调用 Context.startForegroundService()。不过,应用必须在创建服务后的五秒内调用该服务的 startForeground() 函数。
     if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) {
        context.startForegroundService(intent);
        } else {
        context.startService(intent);
        }
    

    startForegroundService中主要是通知创建service 并发送一个延迟5s的msg,5s后就会抛出异常。
    在service创建之后会调用onCreate中手动添加的startForeground,它的作用是添加notification避免 “null notification”(startForeground方法参数会传入一个notification);同时移除了startForegroundService中发出的超时msg 避免了Context.startForegroundService() did not then call Service.startForeground()异常。

    相关文章

      网友评论

        本文标题:Android service笔记

        本文链接:https://www.haomeiwen.com/subject/gfytmqtx.html