Android借助Application重写App的Crash(简易版)


原文:http://blog.csdn.net/lfdfhl/article/details/9714443

MainActivity如下:

package cn.testcrash;
import android.app.Activity;
import android.os.Bundle;
/**
 * Demo描述:
 * 借助于Application自定义Crash
 * 
 * 参考资料:
 * 1 http://blog.csdn.net/xiaanming/article/details/9344703
 * 2 http://blog.csdn.net/itachi85/article/details/9102021
 */
public class MainActivity extends Activity {
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
	}
	//Crash
	private void init(){
		System.out.println((9727/0)+"");
	}
}


CrashApplication如下:

package cn.testcrash;
import android.app.Application;

public class CrashApplication extends Application {
	@Override
	public void onCreate() {
		super.onCreate();
		CrashHandler crashHandler=CrashHandler.getInstance();
		//指定Crash时的处理程序
		crashHandler.setCrashHandler(getApplicationContext());
	}
}

CrashHandler如下:

package cn.testcrash;
import java.lang.Thread.UncaughtExceptionHandler;
import android.content.Context;
import android.os.Looper;
import android.widget.Toast;
public class CrashHandler implements UncaughtExceptionHandler {
	private Context mContext;
	private static CrashHandler mCrashHandler=new CrashHandler();
	
	public static CrashHandler getInstance(){
		return mCrashHandler;
	}
	
	/**
	 * 设置当线程由于未捕获到异常而突然终止的默认处理程序。
	 */
	public void setCrashHandler(Context context){
		mContext=context;
		Thread.setDefaultUncaughtExceptionHandler(this);
	}
	
	/**
	 * 当发生Crash时调用该方法
	 */
	@Override
	public void uncaughtException(Thread thread, Throwable throwable) {
		 //保存错误日志到SD卡
         Utils.saveInfoToSDCard(mContext, throwable);
         //提示Crash信息
         showCrashTipToast();
         try {
			Thread.sleep(3000);
		} catch (Exception e) {
		}
         //退出应用
         System.exit(0);
	}
	
	private void showCrashTipToast() {
		new Thread(new Runnable() {
			@Override
			public void run() {
				Looper.prepare();
				Toast.makeText(mContext, "I am very sorry", Toast.LENGTH_LONG).show();
				Looper.loop();
			}
		}).start();
	}

}

Utils如下:

package cn.testcrash;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.TimeZone;
import android.content.Context;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.os.Build;

public class Utils {

	public static void saveInfoToSDCard(Context context, Throwable throwable) {
		HashMap<String, String> hashMap=getBaseInfo(context);
		StringBuilder stringBuilder=new StringBuilder();
		for(Map.Entry<String, String> entry:hashMap.entrySet()){
			String key=entry.getKey();
			String value=entry.getValue();
			stringBuilder.append(key).append("=").append(value).append("\n");
		}
        System.out.println("stringBuilder.toString()如下:"+"\n"+stringBuilder.toString());
        
        /**
         * 其余逻辑省略
         */
	}
	/**
	 * 获取设备及该App的基本信息
	 */
	public static HashMap<String, String> getBaseInfo(Context context){
		HashMap<String, String> hashMap = new HashMap<String, String>();
		PackageManager packageManager = context.getPackageManager();
		PackageInfo packageInfo = null;
		try {
			packageInfo = packageManager.getPackageInfo(context.getPackageName(), PackageManager.GET_ACTIVITIES);
		} catch (NameNotFoundException e) {
			e.printStackTrace();
		}
		
		hashMap.put("versionName", packageInfo.versionName);
		hashMap.put("versionCode", packageInfo.versionCode+"");
		
		hashMap.put("MODEL",  Build.MODEL+"");
		hashMap.put("SDK_INT",Build.VERSION.SDK_INT+"");
		hashMap.put("RELEASE",Build.VERSION.RELEASE+"");
		hashMap.put("PRODUCT",Build.PRODUCT+"");
		return hashMap;
	}
	
	
	
	private String getCurrentTime(){
		String currentTime="";
		long currentTimeMillis=System.currentTimeMillis();
		System.setProperty("user.timezone", "Asia/Shanghai");  
		TimeZone timeZone = TimeZone.getTimeZone("Asia/Shanghai");  
		TimeZone.setDefault(timeZone);  
		SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss");
		Date currentDate=new Date(currentTimeMillis);
		currentTime = simpleDateFormat.format(currentDate);  
        System.out.println("currentTime="+currentTime);
        return currentTime;
	}
	 

}

AndroidManifest.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="cn.testcrash"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="8" />

    <application
        android:name="cn.testcrash.CrashApplication"
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="cn.testcrash.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

安卓开发论坛    http://www.eoeandroid.com/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值