崩溃解决的思路
要考虑的方面:机型,系统,厂商,cpu,ABI,LINUX ,是否root ,是不是模拟器
内存信息的读取:
1系统剩余内存:/proc/meminfo
2应用使用内存:包括java内存,RSS(Resident Set Size)PSS(Proportional Set Size)
PSS 和RSS通过/proc/selt/smap计算
3虚拟内存:/proc/self/status 可以看/proc/slef/maps问价得到具体分布情况
进程允许打开的额最大文件句柄数1024个 超过800个时就容易出现崩溃,要排查是否有文件或者线程泄露
崩溃分 java崩溃,native崩溃 ,anr
谈谈
java.util.concurrent.TimeoutException:
利用反射的方式关掉守护线程可以规避这个异常
try {
final Class clazz = Class.forName("java.lang.Daemons$FinalizerWatchdogDaemon");
final Field field = clazz.getDeclaredField("INSTANCE");
field.setAccessible(true);
final Object watchdog = field.get(null);
try {
final Field thread = clazz.getSuperclass().getDeclaredField("thread");
thread.setAccessible(true);
thread.set(watchdog, null);
} catch (final Throwable t) {
Log.e(TAG, "stopWatchDog, set null occur error:" + t);
t.printStackTrace();
try {
// 直接调用stop方法,在Android 6.0之前会有线程安全问题
final Method method = clazz.getSuperclass().getDeclaredMethod("stop");
method.setAccessible(true);
method.invoke(watchdog);
} catch (final Throwable e) {
Log.e(TAG, "stopWatchDog, stop occur error:" + t);
t.printStackTrace();
}
}
} catch (final Throwable t) {
Log.e(TAG, "stopWatchDog, get object occur error:" + t);
t.printStackTrace();
}