Android ANR的解决方案

1、使用monkey进行压测,命令如下:

bash 复制代码
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 in
	Reason
	"main" prio=
	Input dispatching timed out
	Broadcast of Intent
	executing service
	ContentProvider not responding
	你的包名

4、使用爱奇艺监听ANR/JAVA崩溃,添加依赖

bash 复制代码
    implementation "com.iqiyi.xcrash:xcrash-android-lib:3.1.0"
bash 复制代码
//	在Application进行初始化工作
public class MyApplication extends Application {
    @Override
    public 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);
    }
}
相关推荐
阿巴斯甜20 小时前
Android 报错:Zip file '/Users/lyy/develop/repoAndroidLapp/l-app-android-ble/app/bu
android
Kapaseker21 小时前
实战 Compose 中的 IntrinsicSize
android·kotlin
xq95271 天前
Andorid Google 登录接入文档
android
黄林晴1 天前
告别 Modifier 地狱,Compose 样式系统要变天了
android·android jetpack
冬奇Lab1 天前
Android触摸事件分发、手势识别与输入优化实战
android·源码阅读
城东米粉儿2 天前
Android MediaPlayer 笔记
android
Jony_2 天前
Android 启动优化方案
android
阿巴斯甜2 天前
Android studio 报错:Cause: error=86, Bad CPU type in executable
android
张小潇2 天前
AOSP15 Input专题InputReader源码分析
android
_小马快跑_2 天前
Kotlin | 协程调度器选择:何时用CoroutineScope配置,何时用launch指定?
android