首页 > 文章列表 > java线程池死锁的产生及处理

java线程池死锁的产生及处理

java 死锁 线程池
217 2022-08-06

说明

1、死锁是指两个或两个以上的过程在实施过程中,由于竞争资源或相互通信而造成的堵塞现象,如果没有外力作用,就不能推进。

线程池死锁实例

2、解决办法:扩大线程池线程或任务结果不再相互依赖。

final ExecutorService executorService =
        Executors.newSingleThreadExecutor();
Future<Long> f1 = executorService.submit(new Callable<Long>() {
 
    public Long call() throws Exception {
        System.out.println("start f1");
        Thread.sleep(1000);//延时
        Future<Long> f2 =
           executorService.submit(new Callable<Long>() {
 
            public Long call() throws Exception {
                System.out.println("start f2");
                return -1L;
            }
        });
        System.out.println("result" + f2.get());
        System.out.println("end f1");
        return -1L;
    }
});

本教程操作环境:windows7系统、java10版,DELL G3电脑。