在Android|在Android Activity中捕获Application Crash
由于接触android开发的时间并不久,对于android系统、机制的理解也是一知半解。所以在开发中陆陆续续遇到很多莫名其妙的问题,其中最让人头疼的就是application crash。application的crash可能由于很多的原因所引起的,有可能是因为数据的问题,或者是异步AsyncTask的运用不合理,等等等等,都可能造成application crash。
也一直在想如何才能知道application crash,想在application crash的时候做点什么,一直也没有找到一个solution。后来在一个偶然的机会用到一个别人的application可以捕获到crash,就想捡到了宝一样。想尽办法去找到这个application的sourcecode,发现原来很简单,几句话就可以做到。
1. 在Activity的onCreate方法里面添加这句话:
Thread.setDefaultUncaughtExceptionHandler(new MyUncaughtExceptionHandler(this));
@Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);
Thread.setDefaultUncaughtExceptionHandler(new UncaughtExceptionHandler(this));
setContentView(R.layout.main);
click2Crash = (Button)findViewById(R.id.clickToCrash);
click2Crash.setOnClickListener(new Button.OnClickListener(){ @Override public void onClick(View v) { String text = "aaa";
System.out.print(text.charAt(10));
}});
}
2. 写一个自己的MyUncaughtExceptionHandler implementes UncaughtExceptionHandler,实现方法uncaughtException。在这个方法里面做任何想做的事情,比如说将造成application crash的原因发送给开发人员。
public class UncaughtExceptionHandler implements java.lang.Thread.UncaughtExceptionHandler { private Context con_;
public UncaughtExceptionHandler(Context con){ this.con_ = con;
} @Override public void uncaughtException(Thread thread, Throwable ex) { StringWriter sw = new StringWriter();
ex.printStackTrace(new PrintWriter(sw));
System.err.println(sw);
Intent bugReportIntent = new Intent(con_, BugReportActivity.class);
bugReportIntent.putExtra(BugReportActivity.exceptionMsg, sw.toString());
con_.startActivity(bugReportIntent);
Process.killProcess(Process.myPid());
System.exit(10);
} }
3. 写一个自己的Activity,告诉用户,你需要这个exception信息,让他Email给开发人员。
public class BugReportActivity extends Activity { public static final String exceptionMsg = "exceptionMsg";
private TextView reportContent;
private Button sendMailBtn;
private Button cancelBtn;
protected void onCreate(Bundle bundle){ super.onCreate(bundle);
Thread.setDefaultUncaughtExceptionHandler(new UncaughtExceptionHandler(this));
setContentView(R.layout.bug_report);
reportContent = (TextView)findViewById(R.id.reportContent);
sendMailBtn = (Button)findViewById(R.id.sendMail);
cancelBtn = (Button)findViewById(R.id.cancel);
String sw = getIntent().getStringExtra(exceptionMsg);
reportContent.setText(sw);
initHandler();
} private void initHandler(){ sendMailBtn.setOnClickListener(new Button.OnClickListener(){ @Override public void onClick(View v) { Toast.makeText(v.getContext(), "Email will be sent to our helpdesk.", Toast.LENGTH_LONG).show();
} });
cancelBtn.setOnClickListener(new Button.OnClickListener(){ @Override public void onClick(View v) { finish();
} });
} }
一直都是看别人的blog学习东西的,今天第一次发个blog。有什么不好的地方请大家见谅。:-)
发现一个GoogleProject专门关注这个Application Crash Report for Android的,简称ACRA.大家可以在下面这个链接上面找到相关内容。
【在Android|在Android Activity中捕获Application Crash】http://code.google.com/p/acra/