android:persistent和android:priority的区别,对进程优先级有什么影响?

前言:写的apk因为系统busy给我kill了,(adj 900): kill all background,在AndroidManifest.xml添加android:persistent="true"后,被甲方要求不能这样做,还是得从adj改,把 priority改成1000

android:persistent和android:priority是两个不同的属性,它们分别用于不同的目的。

  1. android:persistent:用于设置应用组件是否具有持久性。当android:persistent设置为true时,表示该组件具有持久性,即使在设备重启后也会保留其状态。而设置为false,则表示该组件不具有持久性,重启后会被销毁。

  2. android:priority:用于设置组件的优先级。这个属性通常用于广播接收器(BroadcastReceiver),可以通过设置android:priority来定义接收广播的顺序和优先级。数值越高表示优先级越高。

这两个属性对进程优先级没有直接的影响。进程优先级是由Android系统动态管理的,根据当前运行的应用程序的活动程度和资源需求来进行调整。系统会根据一些因素(例如用户当前正在与之交互的应用、前台服务等)来确定进程的优先级。

虽然android:priority可以在某种程度上影响广播接收器的执行顺序,但它并不会直接影响进程的优先级。进程的优先级是由系统根据一系列的策略和算法来决定的,而不仅仅取决于某个组件的属性设置。


关于Service保活和提高Android应用中Service组件优先级的方法,可以总结如下:

  1. 设置最高优先级:在AndroidManifest.xml文件中,通过设置android:priority属性为较高的值(例如1000)来设置最高优先级。这适用于广播接收器。

  2. 使用startForeground()方法:在Service的onStartCommand()方法中调用startForeground()方法,将Service提升为前台进程级别。在Service的onDestroy()方法中记得调用stopForeground()方法。

  3. 返回START_STICKY:在Service的onStartCommand()方法中手动返回START_STICKY,以便在Service被系统销毁后能够重新启动。

  4. 发送广播重启Service:在Service的onDestroy()方法中发送一个自定义广播,在收到广播后重新启动Service。请注意,这种方式无法保证在第三方应用或系统设置中强制停止应用时能够执行。

  5. 监听系统广播判断Service状态:通过监听系统广播,如手机重启、界面唤醒、应用状态改变等,判断Service是否存活。

  6. 多个App相互拉活:不同的App之间相互绑定、互相拉活。

  7. 设置闹钟定时唤醒:使用AlarmManager设置闹钟,在指定时间周期性地唤醒Service。

  8. 开启前台Service:将Service设置为前台Service,提高其优先级。

  9. Service中循环播放无声音频:在Service中循环播放一段无声音频,可以一定程度上提高保活效果,但会增加耗电量。

  10. 双进程守护(Android 5.0前有效):通过启动一个独立的守护进程与主进程相互监控和拉活。

  11. JobScheduler(Android 5.0后引入,8.0后失效):使用JobScheduler调度任务来定期唤醒Service。

  12. 像素Activity保活方案(不推荐):创建一个透明的1像素Activity,并设置为悬浮窗口,以维持应用的运行。

  13. 广播锁屏、自定义锁屏(不推荐):通过监听锁屏广播或自定义锁屏界面来保活,但这种方式可能对用户体验产生负面影响。

  14. 第三方推送SDK唤醒:使用第三方推送SDK的唤醒机制来保活,但需要接入第三方服务。

  15. Native层fork子进程:在native层创建一个子进程并与主进程进行通信,实现互相拉活。

  16. 与手机厂商沟通:与手机厂商沟通,将应用放入系统白名单,降低oom_adj值,以确保进程不被系统杀死。

  17. 在AndroidManifest.xml中添加Persistent属性:在application节点中添加android:persistent="true"属性,表示应用具有持久性。

tips:以上方法的适用性和效果可能因Android版本、设备品牌和系统策略等因素而有所差异。

android:persistent和android:priority的区别,对进程优先级有什么影响?_第1张图片

确实,通过将自己的应用作为系统应用(安装目录为/system/apk/),并设置android:persistent="true"属性,可以实现持久性,即应用会在系统启动时加载,并在异常出现时自动重新启动。

实现这种持久性的原理是,AMS(ActivityManagerService)在系统启动时加载所有persistent为true的应用。对于persistent应用,当应用进程意外终止时,AMS会尝试重新启动该应用进程,以保证应用的持久性。

需要注意的是,这种方法只适用于将应用作为系统应用安装的情况,安装在/system/apk/目录下。普通应用安装后路径为/data/apk/,即使设置了android:persistent属性也不会生效。

使用一句代码搞定事情的前提是将应用作为系统应用,并重启手机后才会生效。但这种方法需要满足特定条件和限制,并且可能不适用于所有场景。因此,为了保证应用的可靠性和稳定性,通常还需要结合其他方法来实现Service保活和提高优先级的需求。

你可能感兴趣的:(安卓,android)