e.printStackTrace(); in string
There are e.printStackTrace()
method to print exceptional error, so I would like to take entire exception in St开发者_C百科ring
and show it by Toast.makeText()
Use the following piece of code:
Writer writer = new StringWriter();
exception.printStackTrace(new PrintWriter(writer));
String s = writer.toString();
There used to be a way to extract an exception stacktrace into the String in one line with Log.getStackTraceString
call. But starting from Android 4.0 (API 14) that method is not reliable anymore, as it returns an empty string for UnknownHostException
(see Android issue #21436 for the details, in short: "to reduce the amount of log spew that apps do in the non-error condition of the network being unavailable" Android engineers made IMHO a dubious decision to modify Log.getStackTraceString
method).
Thus it is better to use the code I provided at the beginning of this post.
import android.util.Log;
...
String stackTrace = Log.getStackTraceString(e);
It's doable, but don't do this. Show just the error message (even that is too much for 'real' users), the full stack trace should go to the log only.
you can print the stack trace to a stream & read from it.
ByteArrayOutputStream baos = new ByteArrayOutputStream();
PrintWriter pw = new PrintWriter(baos);
e.printStackTrace(pw);
String stachTrace = new String(baos.toByteArray());
or you can use a StringWriter in place of the ByteArrayOutputStream.
In your exception handler use:
StringWriter sw = new StringWriter();
PrintWriter pw = new PrintWriter(sw);
e.printStackTrace(pw);
whateverFunctionYouLikeToPrintYourStackTrace(sw.getBuffer().toString());
However, you're much better off using ADB with logcat, because stack traces on Toasts look terrible.
精彩评论