Я хотел бы получать данные журнала ошибок из приложения при его сбое. Приложение может иметь исключение нулевого указателя или что-то еще, когда оно возникает, я хочу записать это в один файл.
Создан обработчик One Exception, как показано ниже.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Java.Lang;
using Java.IO;
using Android.Util;
namespace errorlogdemo
{
class ExceptionHandler: Java.Lang.Thread.IUncaughtExceptionHandler
{
private Java.Lang.Thread.IUncaughtExceptionHandler defaultUEH;
private Activity app = null;
private string localPath;
public ExceptionHandler(Activity app) {
this.defaultUEH = Java.Lang.Thread.DefaultUncaughtExceptionHandler;
this.app = app;
this.localPath = "/data/data/appname/files";
}
private void writeToFile(string stacktrace, string filename) {
try {
BufferedWriter bos = new BufferedWriter(new FileWriter(
localPath + "/" + filename));
bos.Write(stacktrace);
Log.Debug("Handler Error",stacktrace);
bos.Flush();
bos.Close();
} catch (Java.Lang.Exception e) {
e.PrintStackTrace();
}
}
#region IUncaughtExceptionHandler implementation
void Thread.IUncaughtExceptionHandler.UncaughtException (Thread thread, Throwable e)
{
Writer result = new StringWriter();
PrintWriter printWriter = new PrintWriter(result);
e.PrintStackTrace(printWriter);
string stacktrace = result.ToString();
printWriter.Close();
string filename = "log.stacktrace";
if (localPath != null) {
writeToFile(stacktrace, filename);
}
defaultUEH.UncaughtException(thread, e);
}
#endregion
}
}
Создан экземпляр для этого обработчика из основного действия:
Java.Lang.Thread.IUncaughtExceptionHandler = new ExceptionHandler (this);
При запуске приложения у меня есть следующее
Button button = null;
button.click+=delegate{
};
Это приведет к сбою приложения, но на этот раз обработчик исключений не вызывается. Почему?
Ссылка: http://schimpf.es/catch-uncaught-exceptions-to-avoid-app-crash/