uncaughtexceptionhandler中的StackOverflower错误

e4eetjau  于 2021-06-30  发布在  Java
关注(0)|答案(2)|浏览(309)

我实现了一个未捕获的异常处理程序来捕获未捕获的异常。但在某个时间或某些设备上,此处理程序失败 java.lang.StackOverflowError . 以下是异常日志:

java.lang.StackOverflowError
at java.lang.AbstractStringBuilder.append0(AbstractStringBuilder.java:121)
at java.lang.StringBuffer.append(StringBuffer.java:278)
at java.io.StringWriter.write(StringWriter.java:123)
at com.android.internal.util.FastPrintWriter.flushLocked(FastPrintWriter.java:358)
at com.android.internal.util.FastPrintWriter.appendLocked(FastPrintWriter.java:303)
at com.android.internal.util.FastPrintWriter.write(FastPrintWriter.java:625)
at com.android.internal.util.FastPrintWriter.append(FastPrintWriter.java:658)
at java.io.PrintWriter.append(PrintWriter.java:691)
at java.io.PrintWriter.append(PrintWriter.java:31)
at java.lang.Throwable.printStackTrace(Throwable.java:324)
at java.lang.Throwable.printStackTrace(Throwable.java:300)
at android.util.Log.getStackTraceString(Log.java:459)
at com.example.src.CustomExceptionHandler.uncaughtException(CustomExceptionHandler.java:36)
at com.example.src.CustomExceptionHandler.uncaughtException(CustomExceptionHandler.java:41)
at com.example.src.CustomExceptionHandler.uncaughtException(CustomExceptionHandler.java:41)

以及导致错误的线路 defaultUEH.uncaughtException(t, e); stacktrace说。
完整代码是:

import java.lang.Thread.UncaughtExceptionHandler;
import android.util.Log;

class CustomExceptionHandler implements UncaughtExceptionHandler {

private UncaughtExceptionHandler defaultUEH;

protected CustomExceptionHandler() {
    try
    {
        this.defaultUEH = Thread.getDefaultUncaughtExceptionHandler();
    }
    catch(Exception e)
    {
        System.out.println("Exception: "+e);
    }
}

public void uncaughtException(Thread t, Throwable e) {
    try
    {
        String stacktrace = Log.getStackTraceString(e);

        SendStackTraceToServer sendStackTraceToServer = new SendStackTraceToServer();
        sendStackTraceToServer.startThreadToSendRequest(stacktrace);

        defaultUEH.uncaughtException(t, e); // this line cause stackoverflow error.
    }
    catch(Exception ex)
    {
        System.out.println("Exception: "+ex);
    }
}

protected static void setDefaultUncaughtExceptionHandler()
{
    Thread.setDefaultUncaughtExceptionHandler(new CustomExceptionHandler());
}
}

帮我解决这个问题。因为我无法复制这个问题(或者我不知道如何复制这个问题)。

8ulbf1ek

8ulbf1ek1#

java.lang.StackOverflower错误不是异常
http://docs.oracle.com/javase/7/docs/api/java/lang/stackoverflowerror.html
如果你需要抓住所有的“可抛弃的”,你可以抓住可抛弃的

nnt7mjpx

nnt7mjpx2#

defaultueh.uncaughtexception(t,e);调用defaultueh.uncaughtexception(t,e);调用defaultueh.uncaughtexception(t,e)。。。最后你得到了StackOverflower。
也许我说的不对,但我觉得你的代码很复杂。
我建议使用如下处理程序:

Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
    @Override
    public void uncaughtException(Thread t, Throwable e) {
        String stacktrace = Log.getStackTraceString(e);
        SendStackTraceToServer sendStackTraceToServer = new SendStackTraceToServer();
        sendStackTraceToServer.startThreadToSendRequest(stacktrace);
    }
});

相关问题