有時會遇到一個問題,系統運行時忽然退出,懷疑執行了System.exit方法,但是無法排查是哪里調用。可通過java的SecurityManager機制來進行檢查。
實現一個繼承SecurityManager的子類,重寫checkExit方法,并通過 -Djava.security.manager設置,就可監測到哪里執行了System.exit方法。
如下列代碼,將執行了System.exit方法打印出來
public class ExitPRintSecurityManager extends SecurityManager { private final int runtimeStackIndex = 3; @Override public void checkExit(int paramInt) { String exitName = "Runtime.exit"; StackTraceElement[] stack = Thread.currentThread().getStackTrace(); if (stack.length > runtimeStackIndex) { int sourceIndex = runtimeStackIndex; StackTraceElement source = stack[sourceIndex]; if ("java.lang.System".equals(source.getClassName()) && "exit".equals(source.getMethodName())) { source = stack[++sourceIndex]; exitName = "System.exit"; } System.out.println(exitName + " in " + source); System.out.println("Stack trace as follows:"); printStack(sourceIndex, stack); } else { System.out.println("Can not print System.exit"); } } private void printStack(int sourceIndex, StackTraceElement[] stack){ for (int i = sourceIndex - 1; i < stack.length; i++) { System.out.println(" " + stack[i]); } } @Override public void checkPermission(Permission perm, Object context) { // allow anything. } @Override public void checkPermission(Permission paramPermission) { // allow anything. }}新聞熱點
疑難解答