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,