开发者

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()

How can i do this?

If there are more alternate idea, then please share with me or suggest me.


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.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜