• Android学习--探究服务(二)


    服务的基本用法


          定义服务: 我们需要先创建服务,我们要使用就的利用一个类去继承它,然后重写它的几个方法,具体的我们看下面的代码:

          我们重写了下面三个方法:

          * onCreate()                 服务创建的时候调用

          * onStartCommand()     每次服务启动的时候调用

          * onDestory()                服务销毁的时候调用

          注意点: 首先要明白我们的onCreate()方法,我们说了它只会在服务被创建的时候调用,之后你开启服务的时候是不会再调用这个onCreate()方法了,没启动一次只会走 onStartCommand()方法,onDestory()是在服务被销毁的时候调用,下面我们再看看它的启动。

    Intent startIntent = new Intent(this,MyService.class);
    
    // 启动服务
    startService(startIntent);
    // 停止服务
    stopService(startIntent);
    

    活动和服务之间的通信


          首先我们的完善我们的服务类,在我们的服务类中添加  Binder 类,这个类会对我们想要在服务类中做的事做一个管理:

    class MyService extends Service{
    
        public MyService() {
        }
    
        private DownloadBinder downloadBinder = new DownloadBinder();
        class DownloadBinder extends Binder{
    
            public void startDownload(){
    
                Log.d("DownloadBinder","startDownload");
            }
    
            public  int getProgress(){
    
                Log.d("DownloadBinder","getProgress");
                return 0;
            }
        }
    
        @Nullable
        @Override
        public IBinder onBind(Intent intent) {
            return downloadBinder;
        }
    
        @Override
        public void onCreate() {
            super.onCreate();
        }
    
        @Override
        public int onStartCommand(Intent intent, int flags, int startId) {
            return super.onStartCommand(intent, flags, startId);
        }
    
        @Override
        public void onDestroy() {
            super.onDestroy();
        }
    }
    

          接着我们看在活动里面是怎样和这个服务类进行一个绑定的,具体的需要注意的地方我们都加了注释,就不在这里在重复,注意看注释就可以:

     /*
        *
        * 首先我们创建一个ServiceConnection匿名类,在里面重写了onServiceConnected和onServiceDisconnected方法
        * 这两个方法分别在活动和服务成功绑定的时候和解绑的时候调用
        *
        * */
        private MyService.DownloadBinder downloadBinder;
        private ServiceConnection connection = new ServiceConnection() {
            @Override
            public void onServiceConnected(ComponentName componentName, IBinder iBinder) {
                // 绑定成之后我们就可以随意的使用调用服务中的方法了
                downloadBinder = (MyService.DownloadBinder) iBinder;
                downloadBinder.startDownload();
                downloadBinder.getProgress();
            }
    
            @Override
            public void onServiceDisconnected(ComponentName componentName) {
    
            }
        };
    
    
        // 绑定和解绑按钮事件来绑定和解绑
        @Override
        public void onClick(View view) {
    
            switch (view.getId()){
                // 活动绑定服务
                case R.id.bind_service:
    
                    // 绑定的时候使用bindService方法,参数分别是 Intent 和 connection
                    Intent bindIntent = new Intent(this,MyService.class);
                    bindService(bindIntent,connection,BIND_AUTO_CREATE);
                    break;
    
                // 活动解绑服务
                case R.id.unbind_service:
    
                    unbindService(connection);
                    break;
    
                default:
                    break;
            }
    
        }
    

    服务的生命周期


      

          我们通过下面的两张图说一下服务的生命周期:

          Service生命周期流程图:

          我们在通过下面的一个调用顺序来解读一下这生命周期:

     

     服务使用的两个小技巧


      

          1、使用前台服务
     
              服务几乎都是在后台运行的,但由于服务的优先级比较低,当系统出现内存不足的情况的时候就有可能回收掉正在后台运行的服务,如果我们想服务一直保持运行状态,而不会由于系统内存不足原因导致服务被回收掉,就可以考虑使用前台服务,前台服务和普通服务最大的区别就在于他会一直有一个正在运行的图标在系统的状态栏显示。
     
              我们通过下面的代码展示如何创建一个前台服务:
     
     
     
          2、使用IntentService
     
               话说回来,在前面我们就有说过,服务中的代码是默认运行在主线程中的,如果直接在服务中处理洗衣额好事的逻辑,就很容易出现ANR (Application Not Responding),所以这个时候我们就需要使用安卓的多线程技术,我们应该在服务中的每个具体的方法里开启一个子线程,然后去处理一些耗时的操作。
     
               按照我们的逻辑,我们就需要开启多线程,执行耗时操作,然后在操作完成之后关闭服务,代码如下:
          可我们还有更简单的方法来做这件事,利用我们要说的 IntentService
      
           通过上面这两篇文章,关于Android服务大概就介绍完了。
  • 相关阅读:
    ORA-06553:PLS-306:wrong number or types of arguments in call to ''
    ORA-06577:output parameter not a bind variable
    CSS3之边框属性border
    Linux_LAMP 最强大的动态网站解决方案
    Linux_LAMP 最强大的动态网站解决方案
    Field BSEG-MWSKZ . does not exist in the screen SAPMF05A 0300 Message no. 00349
    mysql group by
    perl 解析JSON
    数组的数组 散列的散列
    HTTP Cookies
  • 原文地址:https://www.cnblogs.com/zhangxiaoxu/p/9481234.html
Copyright © 2020-2023  润新知