Android ANR的解决方案
1、使用monkey进行压测,命令如下:
adb shell monkey -p com.toycloud.alphaegg.launcher --hprof --ignore-crashes --ignore-timeouts --ignore-security-exceptions --pct-syskeys 0 --throttle 100 -v -v -v 10000 > C:\Users\jjyang31\Desktop\public_apk\Monkeytest_20251103\"monkeytest_%date:~0,4%-%date:~5,2%-%date:~8,2% %time:~0,2%-%time:~3,2%-%time:~6,2%.log"
// 100 是间隔时间 10000模拟触摸次数
2、执行完毕后通过adb bugreport 自动把anr相关的日志打包下载。
3、通过关键字搜索日志:
ANR inReason"main" prio=Input dispatching timed outBroadcast of Intentexecuting serviceContentProvider not responding你的包名
4、使用爱奇艺监听ANR/JAVA崩溃,添加依赖
implementation "com.iqiyi.xcrash:xcrash-android-lib:3.1.0"
// 在Application进行初始化工作
public class MyApplication extends Application {@Overridepublic void onCreate() {super.onCreate();String filePath = getCacheDir().getAbsolutePath() + "/xcrash";Log.d("MyApplication", "filePath=" + filePath);XCrash.InitParameters params = new XCrash.InitParameters().setLogDir(filePath).setJavaCallback((logPath, emergency) -> {// Java 崩溃回调Log.d("xCrash", "Java crash captured: " + emergency);// 可以在这里上传日志到服务器}).setNativeCallback((logPath, emergency) -> {// Native 崩溃回调Log.d("xCrash", "Native crash captured: " + emergency);}).setAnrCallback((logPath, emergency) -> {// ANR 回调Log.d("xCrash", "ANR captured: " + emergency);});XCrash.init(this, params);}
}
