Service优先级提高

来源:互联网 发布:列克星敦战巡数据 编辑:程序博客网 时间:2024/05/22 01:42
Android系统定义的进程优先级有六种:
    1、前台进程(FOREGROUND_APP) 
    2、可视进程(VISIBLE_APP)
    3、次要服务进程(SECONDARY_SERVICE) 
    4、后台进程(HIDDEN_APP)  
    5、内容供应节点(CONTENT_PROVIDER)  
    6、空进程(EMPTY_APP)

当Android系统内存不足时会kill一些应用进程,而kill哪个是根据这个优先级来判断的,优先级低的优先被kill。

那么,问题来了?
我们为了避免Service被kill,应该提高Service的进程优先级,那么如何提供Service的优先级呢??

重写onStartCommand方法,使用StartForeground(int,Notification)方法来启动service。
注:前台服务会在状态栏显示一个通知,最典型的应用就是音乐播放器,只要在播放状态下,就算休眠也不会被杀,如果不想显示通知,只要把参数里的int设为0即可

Notification notification = new Notification(R.drawable.logo,                "wf update service is running",                System.currentTimeMillis());        pintent=PendingIntent.getService(this, 0, intent, 0);        notification.setLatestEventInfo(this, "WF Update Service",                "wf update service is running!", pintent);                    //让该service前台运行,避免手机休眠时系统自动杀掉该服务        //如果 id 为 0 ,那么状态栏的 notification 将不会显示。        startForeground(startId, notification);

同时,对于通过startForeground启动的service,onDestory方法中需要通过stopForeground(true)来取消前台运行状态。

ps:如果service被杀后下次重启出错,可能是此时重发的Intent为null的缘故,可以通过修改onStartCommand方法的返回值来解决:

START_STICKY:如果service进程被kill掉,保留service的状态为开始状态,但不保留递送的intent对象。随后系统会尝试重新创建service,由于服务状态为开始状态,所以创建服务后一定会调用onStartCommand(Intent,int,int)方法。如果在此期间没有任何启动命令被传递到service,那么参数Intent将为null。

START_NOT_STICKY:“非粘性的”。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统不会自动重启该服务。

START_REDELIVER_INTENT:重传Intent。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统会自动重启该服务,并将Intent的值传入。

START_STICKY_COMPATIBILITY:START_STICKY的兼容版本,但不保证服务被kill后一定能重启。



0 0
原创粉丝点击