Java多线程任务和阻塞队列实现生产者消费者封装

1.多线程任务

使用线程池执行多线程任务

我们使用多线程做一些业务操作时主要有自己继承Thread类,或者实现Runable接口实现,但是自己创建线程都不利于线程的管理和回收,这个时候我们就考虑使用线程池了,我们常用创建线程池的方式是通过Executors类的new...Pool()方法创建线程池,笔者开始也是这样(笔者使用的是IDEA,安装了阿里的代码规范)但是在newFixedThreadPool()时阿里规范提示最好自己创建线程

ExecutorService service = Executors.newFixedThreadPool();

 于是看了下newFixedThreadPool()方法其实是new ThreadPoolExecutor(),将参数给死了队列的长度没有给定

继续看LinkedBlockingQueue的这个构造方法长度是正数的最大值,所以阿里代码规约说会报OOM

修改代码

ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("thread-call-runner-%d").build();
        ThreadPoolExecutor pool = new ThreadPoolExecutor(consumerThread, consumerThread,
                0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>(), namedThreadFactory);

使用CountDownLatch控制线程执行退出

为了解决子线程执行完所有任务后线程假死状态,同时为了控制主线程在子线程执行时是等待主线程执行,还是退出我们使用CountDownLatch,

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值