• Java处理Exception无法捕获的异常


    场景

    使用try...catch(Exception e){}来捕获异常,执行过程中线程中断或阻塞了,但是catch块中却并没有捕获到异常信息。

    try{
       // 此处可能是调用一个远程的接口,或是调用了某个jar包中的方法。
    
       // 此处出现了异常,线程中断或阻塞了,不再继续往下执行
    }catch(Exception e){   e.printStackTrace();   // 此处却没有异常的信息出现 }

    网搜到的解决办法原文

    来源于某个bbs地址:http://bbs.csdn.net/topics/390952122?locationNum=7

    bbs中推荐网址:http://blog.csdn.net/trendgrucee/article/details/17656217

    记录一下原文中的解决方案

    step1: 写一个异常处理类

    为了解决线程意外终止,确无法捕获异常,无法判断原因。可以使用Thread.UncaughtExceptionHandler。

    public class MyUncaughtExceptionHandler implements Thread.UncaughtExceptionHandler {
    
        @Override
        public void uncaughtException(Thread t, Throwable e) {
            // 打印出现异常的线程和异常名称
            System.out.println("捕获到异常 : 线程名[" + t.getName() + "], 异常名[" + e + "]");
            
            // 异常栈的信息
            e.printStackTrace();
            
            // TODO ... 如果对异常还需要做特殊处理,可以在此处继续实现处理方法
        }
    
    }

    step2:测试异常处理类是否可以捕获异常

    2.1 先写一个会抛出异常的线程

    public class ExceptionThread implements Runnable {
    
        @Override
        public void run() {
            // 线程信息
            Thread t = Thread.currentThread();
            System.out.println("执行线程:" + t);
            System.out.println("异常被谁处理:" + t.getUncaughtExceptionHandler());
    
            // 抛出异常
            throw new RuntimeException();
        }
    
    }

    2.2 测试类的main方法中设置线程的异常处理器,并执行会抛出异常的线程(异常处理器使用示例

    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    
    public class SettingDefaultHandler {
    
        public static void main(String[] args) {
            // 设置线程的异常处理器
            Thread.setDefaultUncaughtExceptionHandler(new MyUncaughtExceptionHandler());
    
            // 执行会抛出异常的线程,看看是否会被捕获
            ExecutorService exec = Executors.newCachedThreadPool();
            exec.execute(new ExceptionThread());
        }
    }

    2.3 执行测试类main方法的打印信息

    执行线程:Thread[pool-1-thread-1,5,main]
    异常被谁处理:java.lang.ThreadGroup[name=main,maxpri=10]
    捕获到异常 : 线程名[pool-1-thread-1], 异常名[java.lang.RuntimeException]
    java.lang.RuntimeException
    	at com.envision.modules.liquid.myExceptionHandler.ExceptionThread.run(ExceptionThread.java:13)
    	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    	at java.lang.Thread.run(Thread.java:745)

     扩展阅读

    ExecutorService 的理解与使用

  • 相关阅读:
    cygwin配合NDK开发Android程序
    和菜鸟一起学c之函数指针
    和菜鸟一起学android4.0.3源码之SD卡U盘等自动挂载配置
    Android系统的开机画面显示过程分析
    android编译系统的makefile文件Android.mk写法
    Linux下makefile教程
    和菜鸟一起学linux之本地git中心仓库建立
    强人总结的Windows XP实用技巧45条(一)
    Webshell下自动挂马的ASP
    多进程Telnet的木马例子
  • 原文地址:https://www.cnblogs.com/zj0208/p/7002508.html
Copyright © 2020-2023  润新知