android service笔记

1、service 默认在主线程运行,所以不能在service中直接做访问网络,操作文件等耗时操作,要另外开启线程

2、通过startservice开启的服务,一旦服务开启,这个服务和开启他的调用者之间就没有任何的关系了,调用者不可以访问 service里面的方法,调用者如果被系统回收了或者调用了ondestroy方法,service还会继续存在

3、通过bindService开启的服务,服务开启之后,调用者和服务之间还存在着联系,一旦调用者挂掉了,service也会跟着挂掉

4、service中可以使用 Toast

5、IntentService是自带一个线程的Service,可以自己关闭,一般用于完成后自动关闭的单线程工作任务

6、Service与Activity之间数据交互三种方式:

一,如果Activity调用Service的方法后能获取返回值,那Activity想什么时候从Service中获取信息就什么时候调用Service中的方法。但是,这种方法有局限性,因为Activity不知道Service中的信息什么时候更新,不能被动的接收信息。

二,利用广播接收者可以解决方法1的局限性,当Service中信息有更新时就发送一个广播到Activity中,Activity中注册一个广播接收者来接收广播,以此来更新Activity中的信息。但是有个疑问,假设频繁的发送广播会不会资源消耗大。

三,写一个回调接口
具体步骤如下:
1.先写一个用来做回调的接口
    public interface ICount {
        void count(int val);
    }
2.Service类
    public class CountService extends Service {
        private int val = 0;

        public void startCount(ICount iCount){ // 调用CountActivity,因为CountActivity实现了ICount
            // do something ...
            val ++;
            iCount.count(val);
        }
    }
3.Activity类
注:省略了绑定CountService的代码
    public class CountActivity extends Activity implements ICount {
        @Override
        protected void onCreate(){
            // do something ...
            startCount(this); // 调用CountService对象的startCount()方法,并把自己传了进入,这样的话CountService对象就能调用自己的方法了
        }

        @Override
        void count(int val){
            // update UI
        }
    }

7、binder可以通过调用transact来从activity发送数据到service,并从service返回数据

8、Service粘性和非粘性

启动service又分为粘性和非粘性:
(1)粘性service:关不掉,由于内存紧张关闭后会重新复活
(2)非粘性service:死了就死了。
区分粘性和非粘性的区别是:看onStartCommand的返回值。
如果在为返回之前系统崩溃,则不存在粘性和非粘性。
非粘性 :返回值是START_NOT_STICKY 系统杀死,再启动需要自己起startService
粘性:返回值START_STICKY 服务死了之后自己起,但是不是调用startSerivce,而是直接调用service的startCommand方法,所有传过来的intent为null.
返回值START_REDELIVER_INTENT: 死了之后系统自己起,但还是会传过来最后一个intent(由于最后一个导致死亡的,所以再传这个intent可能还会死亡,但是死了四五次就不会再自动启动了。)

9、进程间可以通过Messager进行通信

10、AIDL demo: http://git.oschina.net/atwal/androidAidlDemo

 

你可能感兴趣的:(android service笔记)