全局捕获异常日志
来源:互联网 发布:win7软件打不开怎么办 编辑:程序博客网 时间:2024/06/07 21:09
实现系统提供的UncaughtExceptionHandler类
import android.content.Context;import android.content.pm.PackageInfo;import android.content.pm.PackageManager;import android.content.pm.PackageManager.NameNotFoundException;import android.os.Build;import android.os.Environment;import android.os.Process;import android.util.Log;import java.io.BufferedWriter;import java.io.File;import java.io.FileWriter;import java.io.IOException;import java.io.PrintWriter;import java.lang.Thread.UncaughtExceptionHandler;import java.text.SimpleDateFormat;import java.util.Date;public class CrashHandler implements UncaughtExceptionHandler { private static final String TAG = "CrashHandler"; private static final boolean DEBUG = true; // 崩溃日志存储位置及文件 private static final String PATH = Environment.getExternalStorageDirectory().getPath() + "/CrashCollect/log/"; private static final String FILE_NAME = "crash"; private static final String FILE_NAME_SUFFIX = ".trace"; private static CrashHandler sInstance = new CrashHandler(); private UncaughtExceptionHandler mDefaultCrashHandler; private Context mCtx; private CrashHandler() { } public static CrashHandler getInstance() { return sInstance; } public void init(Context context) { mDefaultCrashHandler = Thread.getDefaultUncaughtExceptionHandler(); Thread.setDefaultUncaughtExceptionHandler(this); mCtx = context.getApplicationContext(); } /** * 这个是最关键的函数,当程序中有未被捕获的异常,系统将会自动调用#uncaughtException方法 * thread为出现未捕获异常的线程,ex为未捕获的异常,有了这个ex,我们就可以得到异常信息 */ @Override public void uncaughtException(Thread thread, Throwable ex) { try { //导出异常信息到SD卡中 dumpExceptionToSDCard(ex); //这里可以通过网络上传异常信息到服务器,便于开发人员分析日志从而解决bug uploadExceptionToServer(); } catch (IOException e) { e.printStackTrace(); } ex.printStackTrace(); //如果系统提供了默认的异常处理器,则交给系统去结束我们的程序,否则就由我们自己结束自己 if (mDefaultCrashHandler != null) { mDefaultCrashHandler.uncaughtException(thread, ex); } else { Process.killProcess(Process.myPid()); } } private void dumpExceptionToSDCard(Throwable ex) throws IOException { //如果SD卡不存在或无法使用,则无法把异常信息写入SD卡 if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) { if (DEBUG) { Log.w(TAG, "sdcard unmounted,skip dump exception"); return; } } File dir = new File(PATH); if (!dir.exists()) { dir.mkdirs(); } long current = System.currentTimeMillis(); String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date(current)); File file = new File(PATH + FILE_NAME + time + FILE_NAME_SUFFIX); try { PrintWriter pw = new PrintWriter(new BufferedWriter(new FileWriter(file))); pw.println(time); dumpPhoneInfo(pw); pw.println(); ex.printStackTrace(pw); pw.close(); } catch (Exception e) { Log.w(TAG, "dump crash info failed"); } } private void dumpPhoneInfo(PrintWriter pw) throws NameNotFoundException { PackageManager pm = mCtx.getPackageManager(); PackageInfo pi = pm.getPackageInfo(mCtx.getPackageName(), PackageManager.GET_ACTIVITIES); pw.print("App Version: "); pw.print(pi.versionName); pw.print('_'); pw.println(pi.versionCode); //android版本号 pw.print("OS Version: "); pw.print(Build.VERSION.RELEASE); pw.print("_"); pw.println(Build.VERSION.SDK_INT); //手机制造商 pw.print("Vendor: "); pw.println(Build.MANUFACTURER); //手机型号 pw.print("Model: "); pw.println(Build.MODEL); //cpu架构 pw.print("CPU ABI: "); pw.println(Build.CPU_ABI); } private void uploadExceptionToServer() { //TODO 上传崩溃信息至服务器 }}
在自己的Application类中初始化崩溃信息收集类CrashHandler
public class CurrentApplication extends Application { private static CurrentApplication sInstance; @Override public void onCreate() { super.onCreate(); sInstance = this; // 在这里为应用设置异常处理程序,然后我们的程序才能捕获未处理的异常 CrashHandler crashHandler = CrashHandler.getInstance(); crashHandler.init(this); } public static CurrentApplication getInstance() { return sInstance; }}
实验一个错误
在Activity中添加
8/0;
后运行public class OneActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_one); int i = 8 / 0; }}
系统文件中会出现崩溃日志文件
如日志显示的错误结果相同,即除0错误
阅读全文
0 0
- 全局捕获异常日志
- Android全局异常捕获日志打印
- 线上发行版捕获全局异常日志的方法
- 全局捕获异常,并输出到日志文件
- Android全局异常捕获,解决日志打印三次的BUG
- Android 全局异常捕获器 保存log日志本地
- c# winform捕获全局异常,并记录日志
- asp.net 程序异常捕获全局处理,生成错误日志
- 全局异常捕获处理
- 程序全局异常捕获
- android 捕获全局异常
- 捕获Application全局异常
- android 捕获全局异常
- Android 捕获全局异常
- android 全局异常捕获
- Winform捕获全局异常
- 捕获全局异常 CrashHandler
- android捕获全局异常
- xshell 连接mac的ssh中文乱码的问题解决
- CentOS7 Yum国内元数据配置
- AOP切面拦截-收集异常
- svn:重命名文件之后,提交失败问题
- SEO优化要注意合理的网站布局
- 全局捕获异常日志
- Coderforces Presents
- 穷举算法求解鸡兔同笼问题(三)
- Android O API 已发布最终版本,快来尝尝鲜
- oracle数据库11g的安装与配置
- 深入Java集合学习系列:HashMap的实现原理
- fastjson-1.2.21 使用实例,复杂嵌套Java对象转json对象,复杂嵌套json对象转对应Java对象的代码实现
- PuTTY (2) Install PuTTY
- android:屏蔽按键进入安全模式