一、服务和进程优先级
1、服务(Service): 是一个没有界面,可以长期运行在后台的应用程序
进程:是应用程序的载体.当应用程序一启动的时候,linux系统就会创建一个进程,这个进程是用来负责运行dalvik虚拟机。而我开发的应用程序就是运行在dalvik虚拟机上的。
退出一个应用程序后,它的进程仍然运行在后台。当手机中的内存空间不够使用时,系统会按照进程的优先级,从低到高,逐级杀死进程,释放空间。
进程的优先级:
1.前台进程(Foreground process)
这个进程运行的软件,界面可见,并且用户可以操作界面。
2.可视进程(Visible process)
这个进程运行的软件,界面可见,但是不能获得焦点,用不能操作界面。比如,有一个透明的界面覆盖住了这个界面。
3.服务进程(Service process)
这个进程运行的软件已经退出,但是后台还运行着一个服务组件。
4.后台进程(Background process)
这个进程运行的软件的界面不可见,但是activity对象没有被销毁;如界面被最小化了
5.空进程(Empty process)
这个进程运行的软件的界面都已经不可见了,应用程已经退出了
二、start开启服务的生命周期(重点)
使用startService方法开启服务的特点:
- 1.第一次开启服务时,先创建服务对象,再开启服务,调用的方法:
onCreate()
onStartCommand()
- 2.停止服务时是把服务对象销毁了;
- 3.服务可以被多次开启,多次开启时,只调用onStartCommand方法;
- 4.服务只能被停止一次,如果多次停止不会执行任何操作;
- 5.界面关闭后,服务仍然运行在后台;
三、bind方式开启服务的生命周期(重点)
特点:
1.第一次绑定服务时,先创建服务对象,再绑定服务,调用的方法:onCreate,onbind;
2.解除绑定的服务时,先解除绑定,再销毁服务对象,调用的方法:onUnbind,onDestroy;
3.服务只能被绑定一次;
4.服务只能被解绑一次,多次解除绑定会抛出异常(Service not registered:服务没有被注册;);
5.界面关闭时,服务被解除绑定,服务对象被销毁.
推荐使用的混合方式:
1.startService:为了让服务能够长期运行在后台;
2.bindService:为了调用服务中的业务方法;
3.unbindService:不再调用服务中的方法,由于前面已经调用了startService方法,在调用unbindservice时不再销毁服务对象,可以让服务长期运行在后台.
4.stopService:为了销毁服务对象;
四、为什么要引入bindservice的API
引入bindservice的API:为了调用服务中的业务方法;
四大组件都必须让系统来启动,否则就没有上下文的特性,就相当于一个普通的类对象;
五、绑定服务调用服务方法的过程
1.在服务的类中写一个中间人的内部类,在这类中写一个方法去调用服务的业务方法;
2.在绑定服务时,让服务给activity返回中间人对象;
3.在activity中,绑定服务成功时得到服务返回的中间人对象;
4.在activity中需要调用服务业务方法的地方,调用中间人的方法, 这样就达到了间接调用服务业务逻辑方法的目的
六、绑定服务抽取接口(重点)
步骤:
1.写一个接口类IService,里面写个方法,这方法就是暴露给activity的方法;
2.在服务的类中,让中间人MyBinder实现IService接口及其中的方法,在这个方法中调用服务的业务方法.
3.在绑定服务时,让服务给activity返回中间人对象;
4.在activity中,绑定服务成功时得到服务返回的IService类型的中间人对象;
5.在activity中需要调用服务业务方法的地方,调用中间人的方法,这样就达到了间接调用服务业务逻辑方法的目的;