Service 应用场景、与 Thread 的区别
Service 是什么
Service 是一个一种在后台长时间执行操作而有没有用户界面的应用组件。
Service 与 Thread 的区别
- Thread
- 最小的运行单元,可以用来执行耗时操作
- Service
- 运行在主线程,不能做耗时操作
- ANR 时间 20s
Service 的两种启动方式
两种启动方式说明
- 启动 当应用组件(如 Activity)通过调用 startService() 启动服务时,服务即处于“启动”状态。一旦启动,服务即可在后台无限期运行,即使启动服务的组件已被销毁也不受影响。 已启动的服务通常是执行单一操作,而且不会将结果返回给调用方。例如,它可能通过网络下载或上传文件。 操作完成后,服务会自行停止运行。
- 绑定 当应用组件通过调用 bindService() 绑定到服务时,服务即处于“绑定”状态。绑定服务提供了一个客户端-服务器接口,允许组件与服务进行交互、发送请求、获取结果,甚至是利用进程间通信 (IPC) 跨进程执行这些操作。 仅当与另一个应用组件绑定时,绑定服务才会运行。 多个组件可以同时绑定到该服务,但全部取消绑定后,该服务即会被销毁。虽然本文档是分开概括讨论这两种服务,但是您的服务可以同时以这两种方式运行,也就是说,它既可以是启动服务(以无限期运行),也允许绑定。问题只是在于您是否实现了一组回调方法:onStartCommand()(允许组件启动服务)和 onBind()(允许绑定服务)。
两种启动方式的生命周期走向
startService 生命周期走向:
- onCreate
- onStartCommand
- onStop
- onDestory
bindService 生命周期走向:
- onCreate
- onBind
- unBindService
- onUnBind
- onDestory
服务保活
无法保证,只能尽量保活
- Manifest 中设置级别(优先级),process
- 提升为前台服务
- 监听系统广播进行唤醒
- 监听其他 APP 的广播
- 将 Service 设置为 START_STICKY,利用系统机制在 Service 挂掉后自动拉活(5 次)
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于