Android借助Application重写App的Crash(完整版)
发布日期:2021-06-30 11:24:22
浏览次数:4
分类:技术文章
本文共 5373 字,大约阅读时间需要 17 分钟。
MainActivity如下:
package cn.testcrash;import android.app.Activity;import android.os.Bundle;/** * Demo描述: * 借助于Application自定义Crash * * 备注说明: * 1 在获取Crash信息后可依据业务上传服务器或者保存至SDCard * 2 在uncaughtException()中的第三步——退出程序.此处只是做了 * 最简单的处理.完备的操作请参见: * http://blog.csdn.net/lfdfhl/article/details/9261147 * http://blog.csdn.net/lfdfhl/article/details/9260605 * * 参考资料: * 1 http://blog.csdn.net/xiaanming/article/details/9344703 * 2 http://blog.csdn.net/itachi85/article/details/9102021 * Thank you very much */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) { //1 保存错误日志到SD卡 Utils.saveCrashInfoToSDCard(mContext, throwable); //2 提示Crash信息 showCrashTipToast(); try { Thread.sleep(3000); } catch (Exception e) { } //3 退出应用 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.io.PrintWriter;import java.io.StringWriter;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 saveCrashInfoToSDCard(Context context, Throwable throwable) { StringBuilder crashInfoStringBuilder=new StringBuilder(); //获取Crash时间 String crashTime=getCrashTime(); crashInfoStringBuilder.append("------------------"+"\n"); crashInfoStringBuilder.append(crashTime+"\n"); crashInfoStringBuilder.append("------------------"+"\n"); //获取Crash时设备及该App的基本信息 HashMaphashMap=getBaseInfo(context); for(Map.Entry entry:hashMap.entrySet()){ String key=entry.getKey(); String value=entry.getValue(); crashInfoStringBuilder.append(key).append("=").append(value).append("\n"); } crashInfoStringBuilder.append("------------------"+"\n"); //获取导致Crash的时间 String uncaughtException=getUncaughtException(throwable); crashInfoStringBuilder.append(uncaughtException+"\n"); crashInfoStringBuilder.append("------------------"+"\n"); System.out.println("crashInfo如下:"+"\n"+crashInfoStringBuilder.toString()); } /** * 获取设备及该App的基本信息 */ public static HashMap getBaseInfo(Context context){ HashMap hashMap = new HashMap (); 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; } /** * 获取造成Crash的异常的具体信息 */ public static String getUncaughtException(Throwable throwable){ StringWriter stringWriter = new StringWriter(); PrintWriter printWriter = new PrintWriter(stringWriter); throwable.printStackTrace(printWriter); printWriter.close(); String uncaughtException=stringWriter.toString(); return uncaughtException; } /** * 获取Crash的时间 */ public static String getCrashTime(){ 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); return currentTime; }}
AndroidManifest.xml如下:
main.xml如下:
转载地址:https://it9527.blog.csdn.net/article/details/9716229 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2024年04月21日 10时15分35秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
leetcode 44. 通配符匹配
2019-04-30
662. 二叉树最大宽度
2019-04-30
剑指 Offer 36. 二叉搜索树与双向链表
2019-04-30
leetcode 82. 删除排序链表中的重复元素 II
2019-04-30
leetcode 1737. 满足三条件之一需改变的最少字符数
2019-04-30
leetcode 378. 有序矩阵中第K小的元素
2019-04-30
刚开始写博客,希望自己能坚持下来,希望能将自己的经验、感悟、知识留下来,助己及人。
2019-04-30
其实“水”题并不水,重视“水”题
2019-04-30
HDOJ1004
2019-04-30
HDOJ-2058 The sum problem(等差数列求和)
2019-04-30
HDOJ-2046 骨牌铺方格(递推)
2019-04-30
HDOJ2045不容易系列之(3)—— LELE的RPG难题(递推)
2019-04-30
HDOJ-2031 进制转换
2019-04-30
杭电2052 Picture
2019-04-30
HDOJ 1009 FatMouse' Trade 贪心算法
2019-04-30
HDOJ 1005 Number Sequence规律题
2019-04-30
一位ACMer过来人的心得
2019-04-30
HDOJ 2057A + B Again十六进制问题
2019-04-30
HDOJ 2089 不要62(数位dp/打表)
2021-07-03
HDOJ 2091 空心三角形
2019-04-30