1.什么是Service?

 Service是一种不提供用户交互页面但是可以在后台长时间运行的组件,可以通过在AndroidManifest.xml设置Service的android:process=":remote"属性,让Service运行另一个进程中,也就是说,虽然你是在当前应用启动的这个Service,但是这个Service和这个应用并不是同一个进程。

2.为什么要使用Service?

因为Service可以运行在不同的进程,这里说一下Android中几种进程的优先级,当系统内存不足时候,系统会从优先级低的进程开始回收,下面根据优先级由高到低列出Android中几种进程。

  • 前台进程,当前用户操作所需要的进程
  • 用户正在交互的Activity(Activity执行了onResume方法)
  • 与正在交互的Activity绑定的Service
  • 设置为前台权限的Service(Service调用startForeground()方法)
  • 正在执行某些生命周期回调的Service,onCreate()、onStart()、onDestroy()
  • 正在执行onReceive()的BroadcastReceiver

这种进程基本不会被回收,只有当内存不足以支持前台进程同时运行时候,系统才回回收它们,主要关注前三个。

  • 可见进程,没有与用户交互所必须的组件,但是在屏幕上仍然可见其内容的进程
  • 调用了onPause()方法但仍对用户可见的Activity
  • 与上面这种Activity绑定的Service
  • 服务进程,使用startService()启动的Service且不属于上面两种类别进程的进程,虽然这个进程与用户交互没有直接关系,但是一般会在后台执行一些耗时操作,所以,只有当内存不足以维持所有前台进程和可见进程同时运行,系统才回回收这个类别的进程。
  • 后台进程,对用户不可见的Activity进程,已调用了onStop()方法的Activity
  • 空进程,不包含任何活动应用组件的进程,保留这种进程唯一目的是作为缓存,缩短引用组件下次启动时间。通常系统会最优先回收这类进程。

此外,一个进程的级别可能会因为其他进程对它的依赖而有所提高,即进程A服务于进程B(B依赖A),那么A的进程级别至少是和B一样高的。

3.Service有几种启动方式?

Service总共有三种启动方式。

  • Scheduled,可定时执行的Service,是Android 5.0(API LEVEL 21)版本中新添加的一个Service,名为JobService,继承Service类,使用JobScheduler类调度它并且设置JobService运行的一些配置。具体文档可以参考JobScheduler,如果你的应用最低支持版本是21,官方建议使用JobService。
  • Started,通过

startService()

  • 启动的Service。通过这种方式启动的Service会独立的运行在后台,即使启动它的组件已经销毁了。例如Activity A使用startService()启动了Service B,过了会儿,Activity A执行onDestroy()被销毁了,如果Service B任务没有执行完毕,它仍然会在后台执行。这种启动方式启动的Service需要主动调用

StopService()

  • 停止服务。
  • Bound,通过

bindService()

  • 启动的Service。通过这种方式启动Service时候,会返回一个客户端交互接口,用户可以通过这个接口与服务进行交互,如果这个服务是在另一个进程中,那么就实现了进程间通信,也就是Messenger和AIDL,这个会是下篇文章的重点。多个组件可以同时绑定同一个Service,如果所有的组件都调用

unbindService()

  • 解绑后,Service会被销毁。

startService和bindService可以同时使用