Service 生命周期的一些注意事项

1. 简单情形

1.1 startService() -> stopService()

  • 调用 startService() 启动服务:
    onCreate() -> onStartCommand()
    之后再多次调用 startService(),只会触发 onStartCommand。任何 Service 都会在系统层面被实现为一个单例,保证同一个 Service 类只会存在一个实例,所以多次调用不会创建多个 Service 实例, onCreate 方法只在初次调用 startService() 时触发。
  • 调用 stopService() 关闭服务:
    onDestroy()

1.2 bindService() -> unbindService()

  • 调用 bindService() 启动并绑定服务:
    onCreate() -> onBind() -> ServiceConnection.onServiceConnected()
    注意
    如果要通过 bindService() 启动一个服务,最后的 flag 参数必须传 BIND_AUTO_CREATE
    如果 Service 的 onBind() 方法返回 null,那么 ServiceConnection.onServiceConnected() 也不会被调用
    如果 bindService() 启动服务之后,又有其他的客户端调用 bindService() 绑定服务,则只会触发 ServiceConnection.onServiceConnected()
  • 调用 unbindService() 解绑服务:
    onUnbind() -> onDestroy()
    注意
    如果 bindService() 启动服务之后,又有其他的客户端调用绑定又解绑服务时,不会触发任何回调。要等到最初启动服务的客户端解绑,才会触发上面的回调。

2. 复杂情形

2.1 startService() -> bindService() -> stopService()

-> onBind() -> ServiceConnection.onServiceConnected()
-> ServiceConnection.onServiceDisconnected() -> onUnbind() -> onDestroy()```
**注意**:
这里 bindService() 的 flag 不能设为 ```BIND_AUTO_CREATE```,否则只调用 stopService() 没有任何效果,需要同时调用 stopService() 和 unbindService() (顺序无所谓)之后,才会触发 ```onUnbind() -> onDestroy()```,并且不会触发 ```ServiceConnection.onServiceDisconnected()```。也就是正常的姐解绑不会触发 ```ServiceConnection.onServiceDisconnected()```,只有绑定一个由 startService() 启动的服务,然后服务又被 stopService() 关闭时,才会触发 ```ServiceConnection.onServiceDisconnected()```

####2.1 bindService() -> startService() -> stopService() + unbindService()
```onCreate() -> onBind() -> ServiceConnection.onServiceConnected()
-> onStartCommand() 
-> onUnbind() -> onDestroy()```
**注意**:
因为用 bindService 启动服务,flag 必然设为了 ```BIND_AUTO_CREATE```,所以要彻底关闭服务,必须同时调用 stopService() 和 unbindService()

###总结
* 一个服务的生命周期中,onCreate(),onBind(),onUnbind() 和 onDestroy() 只会被调用一次,而 onStartCommand() 会被多次调用。
* 如果bindService() 时,flag 被设为了 ```BIND_AUTO_CREATE```,那么不管该 Service 是如何启动的,它都没办法被 stopService() 命令强行中断

你可能感兴趣的:(Service 生命周期的一些注意事项)