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/

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章