IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> excessive cpu 优化杀进程解决方案 android P -> 正文阅读

[移动开发]excessive cpu 优化杀进程解决方案 android P

背景:

? ? ? ?android系统优化电池使用,在应用退到后台后会判断应用是否还在使用cpu,如果在指定时间内使用cpu到一定程度就会杀进程,报ActivityManager: Killing 9553:com.oushang.screen/1000 (adj 700): excessive cpu 56840 during 300080 dur=623325 limit=10这个错。车机需要排除排除这种情况下杀carlink进程,在checkExcessivePowerUsageLocked种修改如下:

第一次修改:


diff --git a/frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java b/frameworks/base/services/core/jav
index f3531c4..b7a7927 100755
--- a/frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java
+++ b/frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java
@@ -24657,7 +24657,11 @@ public class ActivityManagerService extends IActivityManager.Stub
                         cpuLimit = mConstants.POWER_CHECK_MAX_CPU_2;
                     } else if (checkDur <= (mConstants.POWER_CHECK_INTERVAL*3)) {
                         cpuLimit = mConstants.POWER_CHECK_MAX_CPU_3;
-                    } else {
+                    } else if ((app.info.packageName.equals("com.oushang.screen"))
+                       && (checkDur <= (mConstants.POWER_CHECK_INTERVAL*12))) {
+                       Slog.d(TAG,"~~~zjy screen delay 1 hour");
+                       cpuLimit = mConstants.POWER_CHECK_MAX_CPU_3;
+                   } else {
                         cpuLimit = mConstants.POWER_CHECK_MAX_CPU_4;
                     }
                     if (((cputimeUsed*100)/uptimeSince) >= cpuLimit) {

后面发现不行,主要是进入这个条件 checkDur <= (mConstants.POWER_CHECK_INTERVAL*3)之后,直接就开始杀进程,后面优化内容如下:

--- a/frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java
+++ b/frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java
@@ -24656,14 +24656,22 @@ public class ActivityManagerService extends IActivityManager.Stub
                             || app.setProcState <= ActivityManager.PROCESS_STATE_HOME) {
                         cpuLimit = mConstants.POWER_CHECK_MAX_CPU_2;
                     } else if (checkDur <= (mConstants.POWER_CHECK_INTERVAL*3)) {
-                        cpuLimit = mConstants.POWER_CHECK_MAX_CPU_3;
-                    } else if ((app.info.packageName.equals("com.oushang.screen"))
-                       && (checkDur <= (mConstants.POWER_CHECK_INTERVAL*12))) {
+                       Slog.d(TAG,"~~~zjy screen delay POWER_CHECK_INTERVAL*3"+",packageName:"+app.info.packageName);
+                        if (app.info.packageName.equals("com.oushang.screen")) {
+                            Slog.d(TAG,"~~~zjy screen delay 1 hour");
+                            cpuLimit = mConstants.POWER_CHECK_MAX_CPU_2;
+                        } else {
+                            cpuLimit = mConstants.POWER_CHECK_MAX_CPU_3;
+                        }
+                   } else if ((app.info.packageName.equals("com.oushang.screen"))
+                       && (checkDur < (mConstants.POWER_CHECK_INTERVAL*12))) {
                        Slog.d(TAG,"~~~zjy screen delay 1 hour");
                        cpuLimit = mConstants.POWER_CHECK_MAX_CPU_3;
                    } else {
+                       Slog.d(TAG,"~~~zjy screen delay POWER_CHECK_MAX_CPU_4"+",packageName:"+app.info.packageName);
                         cpuLimit = mConstants.POWER_CHECK_MAX_CPU_4;
                     }
+                   Slog.d(TAG, "~~~zjy screen delay cputimeUsed:"+cputimeUsed*100+",uptimeSince:"+uptimeSince+",cpuLimit:"+cpuLimit+
                     if (((cputimeUsed*100)/uptimeSince) >= cpuLimit) {
                         synchronized (stats) {
                             stats.reportExcessiveCpuLocked(app.info.uid, app.processName,

修改后的内容如下:

// What is the limit for this process?
                    int cpuLimit;
                    long checkDur = curUptime - app.whenUnimportant;
                    if (checkDur <= mConstants.POWER_CHECK_INTERVAL) {
                        cpuLimit = mConstants.POWER_CHECK_MAX_CPU_1;
                    } else if (checkDur <= (mConstants.POWER_CHECK_INTERVAL*2)
                            || app.setProcState <= ActivityManager.PROCESS_STATE_HOME) {
                        cpuLimit = mConstants.POWER_CHECK_MAX_CPU_2;
                    } else if (checkDur <= (mConstants.POWER_CHECK_INTERVAL*3)) {
                        Slog.d(TAG,"~~~zjy screen delay POWER_CHECK_INTERVAL*3"+",packageName:"+app.info.packageName);
                        if (app.info.packageName.equals("com.oushang.screen")) {
                            Slog.d(TAG,"~~~zjy screen delay 1 hour");
                            cpuLimit = mConstants.POWER_CHECK_MAX_CPU_2;
                        } else {
                            cpuLimit = mConstants.POWER_CHECK_MAX_CPU_3;
                        }
                    } else if ((app.info.packageName.equals("com.oushang.screen"))
                        && (checkDur < (mConstants.POWER_CHECK_INTERVAL*12))) {
                        Slog.d(TAG,"~~~zjy screen delay 1 hour");
                        cpuLimit = mConstants.POWER_CHECK_MAX_CPU_2;
                    } else {
                        Slog.d(TAG,"~~~zjy screen delay POWER_CHECK_MAX_CPU_4"+",packageName:"+app.info.packageName);
                        cpuLimit = mConstants.POWER_CHECK_MAX_CPU_4;
                    }
                    Slog.d(TAG, "~~~zjy screen delay cputimeUsed:"+cputimeUsed*100+",uptimeSince:"+uptimeSince+",cpuLimit:"+cpuLimit+",checkDur:"+checkDur);
                    if (((cputimeUsed*100)/uptimeSince) >= cpuLimit) {
                        synchronized (stats) {
                            stats.reportExcessiveCpuLocked(app.info.uid, app.processName,
                                    uptimeSince, cputimeUsed);
                        }

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-03-24 00:42:07  更:2022-03-24 00:43:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 19:28:00-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码