余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

分析手机安装60个应用后,系统变得非常卡

xiyangw 2023-10-03 16:14 34 浏览 0 评论

问题:手机安装60个应用后,系统变得非常卡

手机:android O(8.0) 最新的机器。

结论: 360手机助手加固功能不适配,引起被加壳的应用走360的dex路径,造成没有正常生成优化文件odex,vdex, 所以每次apk露面的时候都会做重复的做而且无用的dex2oat动作,造成系统卡顿。

分析:

1,在打开一些应用后手机就变得非常的卡,慢。打印log发现dex2oat 编译做的非常频繁。这个肯定会强制很多的CPU,而且dex2oat会短时间内让手机所有进程暂时暂停一下。所以dex2oat过多频繁的话会照成系统卡顿。 log 如下, 迅雷 应用由于安装的时候是quicken模式,在打开的时候会做很多dex2oat , 包括他的lib库也是要做的.

04-03 13:51:42.150 26800 26800 I dex2oat : /system/bin/dex2oat --input-vdex-fd=-1 --output-vdex-fd=18 --compiler-filter=quicken --classpath-dir=/data/app/com.xunlei.downloadprovider-PmpNZvip8SWSJDfgKxYPSw== --class-loader-context=PCL[/system/framework/android.test.mock.jar:/system/framework/android.test.runner.jar]

04-03 13:51:42.159 26800 26800 W dex2oat : Could not reserve sentinel fault page

04-03 13:51:42.701 26800 26800 I dex2oat : dex2oat took 552.891ms (353.157ms cpu) (threads: 2) arena alloc=7KB (7312B) java alloc=32KB (32832B) native alloc=1305KB (1336912B) free=1254KB (1284528B)

04-03 13:53:02.491 27454 27454 W dex2oat : Using default instruction set features for ARM CPU variant (default) using conservative defaults

04-03 13:53:02.492 27454 27454 I dex2oat : The ClassLoaderContext is a special shared library.

04-03 13:53:02.493 27454 27454 I dex2oat : /system/bin/dex2oat --dex-file=/data/data/com.xunlei.downloadprovider/app_baidu_ad_sdk/__xadsdk__remote__final__running__.jar --output-vdex-fd=143 --oat-fd=144 --oat-location=/data/data/com.xunlei.downloadprovider/app_baidu_ad_sdk/oat/arm/__xadsdk__remote__final__running__.odex --compiler-filter=quicken --class-loader-context=&

04-03 13:53:02.499 27454 27454 W dex2oat : Could not reserve sentinel fault page

04-03 13:53:02.598 27463 27463 W dex2oat : Using default instruction set features for ARM CPU variant (default) using conservative defaults

04-03 13:53:02.598 27463 27463 I dex2oat : The ClassLoaderContext is a special shared library.

04-03 13:53:02.599 27463 27463 I dex2oat : /system/bin/dex2oat --dex-file=/data/data/com.xunlei.downloadprovider/app_e_qq_com_plugin/gdt_plugin.jar --output-vdex-fd=150 --oat-fd=151 --oat-location=/data/data/com.xunlei.downloadprovider/app_e_qq_com_plugin/oat/arm/gdt_plugin.odex --compiler-filter=quicken --class-loader-context=&

04-03 13:53:02.640 27463 27463 W dex2oat : Could not reserve sentinel fault page

04-03 13:53:03.525 27454 27454 I dex2oat : dex2oat took 1.035s (671.327ms cpu) (threads: 2) arena alloc=2240B (2240B) java alloc=393KB (402896B) native alloc=1158KB (1186760B) free=2MB (2483256B)

04-03 13:53:03.758 27463 27463 I dex2oat : dex2oat took 1.162s (657.150ms cpu) (threads: 2) arena alloc=2736B (2736B) java alloc=246KB (252176B) native alloc=1238KB (1268448B) free=1833KB (1877280B)

04-03 13:53:10.854 27664 27664 W dex2oat : Using default instruction set features for ARM CPU variant (default) using conservative defaults

04-03 13:53:10.856 27664 27664 I dex2oat : /system/bin/dex2oat --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex!classes2.dex --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex!classes3.dex --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex!classes4.dex --oat-file=/data/data/com.xunlei.downloadprovider/.jiagu/oat/arm/classes.odex --inline-max-code-units=0 --compiler-filter=speed

04-03 13:53:10.860 27664 27664 E dex2oat : Expected valid zip or dex file: '/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex'

04-03 13:53:10.862 27664 27664 I dex2oat : dex2oat took 9.340ms (7.456ms cpu) (threads: 2)

2, 但是比较奇怪的是,每次打开迅雷都会做dex2oat。 这就不正常了, 因为做过一次后就不会做了的。

04-03 14:00:00.908 29373 29373 I dex2oat : /system/bin/dex2oat --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex!classes2.dex --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex!classes3.dex --dex-file=/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex!classes4.dex --oat-file=/data/data/com.xunlei.downloadprovider/.jiagu/oat/arm/classes.odex --inline-max-code-units=0 --compiler-filter=speed

04-03 14:00:00.912 29373 29373 E dex2oat : Expected valid zip or dex file: '/data/data/com.xunlei.downloadprovider/.jiagu/classes.dex'

3, 进入到log说道的这个目录:/data/data/com.xunlei.downloadprovider/.jiagu/oat/arm/ 居然发现odex, vdex文件均为0. 也就是说根本没有生成可用的优化文件。

/data/data/com.xunlei.downloadprovider/.jiagu/oat/arm # ls -l

total 0

-rw-r--r-- 1 u0_a113 u0_a113 0 2018-04-03 14:00 classes.odex

-rw-r--r-- 1 u0_a113 u0_a113 0 2018-04-03 14:00 classes.vdex

4, 但是/data/app目录下有安装的时候生成的odex, vdex:

/data/app/com.xunlei.downloadprovider-PmpNZvip8SWSJDfgKxYPSw==/oat/arm # ls -l

total 8260

-rw-r--r-- 1 system all_a113 41384 2018-04-03 13:51 base.odex

-rw-r--r-- 1 system all_a113 8402276 2018-04-03 13:51 base.vdex

5, 把/data/app下面的odex, vdex拷贝到.jiagu/oat/arm 目录下, 在启动这个进程就不会有dex2oat产生了。所以问题找到, 而且系统也不卡了。

6, 这个.jiagu 这个目录是谁创建的, 我们系统源码中并没有地方会创建这个隐藏文件。通过查找资料,发现这是360手机助手的 app加固功能。 即开发者上传app的时候选择了360应用加固,360就会分析apk的源码,并给apk加一层壳,使得360可以在这些应用的欢迎页面等地方加上自己的logo和广告都是可以的。并且360重写了系统方法做dex会走360自己的dex提取方法。所以提取的文件会放到.jiagu的隐藏文件中。并且他没有适配最新的android 8.0 , 所以出现了此问题。也不知道他还干了什么别的隐藏功能没,比较后怕的一种行为。

7, 当安装一个叫"米粒"桌面应用, 也会发生这样的情况。 桌面是用户使用率很高的应用。 每次按back, home key退出到桌面都做一次dex2oat, 那系统就卡顿的频率就非常多了。用户体验就很糟糕。

8, 从google play store 安装应用,检查了一下不存在这样的问题。

相关推荐

华为交换机配置命令总结

1、配置文件相关命令[Quidway]displaycurrent-configuration显示当前生效的配置[Quidway]displaysaved-configuration显示fla...

解决账户无法登录的故障
解决账户无法登录的故障

在优化系统时错误地根据网上的提示,将唯一的Administrator账户设置为禁用,导致重启后无法进入系统。类似的故障还有使用组策略限制本地账户登录,导致重启后...

2023-10-11 17:16 xiyangw

S5720交换机登录提示初始密码存在安全风险
S5720交换机登录提示初始密码存在安全风险

问题描述客户每次登录输密码时,提示初始密码不安全,现在客户嫌麻烦想要去掉:Username:huaweiPassword:Warning:Theinitia...

2023-10-11 17:15 xiyangw

Springboot,Mybatis修改登录用户的密码
Springboot,Mybatis修改登录用户的密码

一、Mybatis.xml<updateid="changePassword"parameterType="string...

2023-10-11 17:15 xiyangw

PHP理论知识之沐浴更衣重看PHP基础(二)
PHP理论知识之沐浴更衣重看PHP基础(二)

接上篇,咱们继续讲解PHP基础八、标准PHP组件和框架的数量很多,随之产生的问题就是:单独开发的框架没有考虑到与其他框架的通信。这样对开发者和框架本身都是不利的...

2023-10-11 17:15 xiyangw

新鲜出炉UCloud云主机“数据方舟”评测报告(5)— — 关其城
新鲜出炉UCloud云主机“数据方舟”评测报告(5)— — 关其城

2015年10月29日,UCloud云主机黑科技——“数据方舟”功能正式上线,首轮内测随即开放。截止至2015年12月6日,我们共收到了534位用户的评测申...

2023-10-11 17:14 xiyangw

业余无线电Q简语及英文缩语
业余无线电Q简语及英文缩语

Q简语:语音通信及CW通信通用(加粗为常用)QRA电台何台QRB电台间之距离QRG告之正确频率QRH频率是否变动QRI发送音调QRJ能否收到QRK信号之可...

2023-10-11 17:14 xiyangw

非常详细!如何理解表格存储的多版本、生命周期和有效版本偏差
非常详细!如何理解表格存储的多版本、生命周期和有效版本偏差

表格存储在8月份推出了容量型实例,直接支持了表级别最大版本号和生命周期,高性能实例也将会在9月中旬支持这两个特性。那么,最大版本号和生命周期以及特有的...

2023-10-11 17:14 xiyangw

H3C交换机恢复出厂和各种基本配置,这20个要点你知道吗?
H3C交换机恢复出厂和各种基本配置,这20个要点你知道吗?

私信“干货”二字,即可领取138G伺服与机器人专属及电控资料!H3C交换机不知道密码如何恢复出厂设置1、开机启动,Ctrl+B进入bootrom菜单,选择恢复出...

2023-10-11 17:13 xiyangw

在使用移动支付系统的时候如何保护信息安全?

移动支付的方式近年来不断被更新,使得Venmo(据嘉丰瑞德理财师了解,此为美国的“支付宝”)之类的支付方式已经可以某种意义上代替随身携带现金了。但是你必须防范那些第三方应用程序轻松地获取你的银行卡以及...

界面控件DevExpress WinForms MVVM入门指南——登录表单(下)

从本文档中,您将了解如何向应用程序添加登录表单。在本节教程中着重讨论了如何实现此任务,这基本上是附加应用程序功能的一部分。DevExpressUniversalSubscription官方最新版免...

linux基础命令(一)
linux基础命令(一)

为啥要学linux?您可能熟悉WindowsXP、Windows7、Windows10和MacOSX等操作系统。Linux就是这样一种强大的操...

2023-10-11 17:13 xiyangw

MySQL数据库密码忘记了,怎么办?

#头条创作挑战赛#MySQL数据库密码忘记了且没有其他可以修改账号密码的账户时怎么办呢?登录MySQL,密码输入错误/*密码错误,报如下错误*/[root@TESTDB~]#mysql-u...

MobaXterm忘记Session密码,如何查看已保存的密码
MobaXterm忘记Session密码,如何查看已保存的密码

MobaXterm工具登录过SSH终端后,如果存储了Session(存储后再连接ssh的时候只需要输入账号不需要输入密码就可以直接连接上ssh),则可以...

2023-10-11 17:12 xiyangw

华为交换机密码丢失修改方法
华为交换机密码丢失修改方法

华为S2300交换机找回密码设置一、目的交换机的console和telnet密码丢失,无法登录设备。交换机已进行过数据配置,要把密码恢复而数据配置不能丢失。二、...

2023-10-11 17:12 xiyangw

取消回复欢迎 发表评论: