1)可以定义一个activity基类,在基类的onPause以及onResume中处理
2)5.1及以后系统,可通过ActivityManager.getRunningTasks判断自己的app是否在前台运行
如果需要监听的程序是第三方开发的,那么
1)在5.0及以磨察扰前系统中,可以通过ActivityManager.getRunningTasks TOP获取前台运行的app信息。没态但在5.0以后,只能判断自己的app是否在前台运行。
2)通过 UsageStatsManager ->queryUsageStats方法获取Top Activity。调用 queryUsageStats 方瞎旦法,有一个限制:需要用户到手机的设置页面 Security->Apps 开启Usage的访问权限!
UncaughtExceptionHandler接口
这个接口,顾名思义,就是处理程序中没有处理的异常,而且是在系统抛出异常导致程序异常终止之前哦!
首先,咱们得创建一个UncaughtExceptionHandler的具体类,比如:
复制内容到剪贴枝毕板
代码:
public class CrashHandler implements UncaughtExceptionHandler {
private static CrashHandler instance //单例引用,这里我们做成单例的,因为我们一个应用程序里面只需要一个UncaughtExceptionHandler实例
private CrashHandler(){}
public synchronized static CrashHandler getInstance(){ //同步方法,以免单例多线程环境下出现异常
if (instance == null){
instance = new CrashHandler()
}
return instance
}
public void init(Context ctx){ //初始化,把当前对象设置成UncaughtExceptionHandler处理器
Thread.setDefaultUncaughtExceptionHandler(this)
}
@Override
public void uncaughtException(Thread thread, Throwable ex) { //当有未处理的异常发生时,就会来到这里。。
Log.d("Sandy", "uncaughtException, thread: " + thread
+ " name: " + thread.getName() + " id: " + thread.getId() + "exception: "
+ ex)
String threadName = thread.getName()
if ("sub1".equals(threadName)){
Log.d("Sandy", ""xxx)
}else if(){
//这里我们可以根据thread name来进行区别对待,同时,我们还可以把异常信息写入文件,以供后来分析。
}
}
}
2. 其次,我们自定义Application类
复制内容到剪贴板
代码:
public class OurApplication extends Application {
@Override
public void onCreate() {
super.onCreate()
CrashHandler handler = CrashHandler.getInstance()
handler.init(getApplicationContext())//在Appliction里面设置我们的异常处理器为UncaughtExceptionHandler处理器
}
}
3. 配置AndroidManifest.xml文件
由于我们使用自定义的Application,所以我们要在AndroidManifest.xml文件中申明它
复制内容到剪贴板
代码:
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:name=".OurApplication"
android:debuggable="true"
>
4. 测试
我们在Activity里面启动一个线液败程,然后线程里面抛出一个异常,看看程序会怎么样
复制内容到剪贴板
代码闹搭颤:
Button btn = (Button) findViewById(R.id.bt)
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
Log.d("Sandy", "I am a sub thread")
String s = null
s.toString() //抛出NullPointException
}
}, "sub thread")
thread.start()
}
5. 结果
由于我们有默认未处理异常的处理程序,所以会打印下面的日志信息,而不会抛出异常导致程序异常终止
D/Sandy ( 2228): I am a sub thread
D/Sandy ( 2228): uncaughtException, thread: Thread[sub thread,5,main] name: sub thread id: 148exception: java.lang.NullPointerException
大家还等什么呢?赶紧在自己的应用里面添加上默认未处理异常处理器吧!再也不会因为异常未捕获发生程序崩溃了。。^_^
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)