• 技术文章 >java >java基础

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

    小妮浅浅小妮浅浅2021-06-17 09:17:36原创3184

    说明

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

    线程池死锁实例

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

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    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;

        }

    });

    以上就是java线程池死锁的产生及处理,希望对大家有所帮助。更多Java学习指路:Java基础

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

    专题推荐:java 线程池 死锁
    上一篇:java使用JConsole检测死锁 下一篇:java中default如何操作接口

    相关文章推荐

    • java BigDecimal的格式化• BigDecimal在java的异常解决• java内存结构的组成• java synchronized的三种同步• java中SPI是什么意思• java中的嵌套类是什么• java内部类的优点• java内部类的使用易错点• java缓存的两种模式• java Redis的缓存使用• java中Memcached和Redis的对比

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网