赞
踩
线程池:顾名思义就是事先创建若干个可执行的线程放入一个池(容器)中,需要的时候从池中获取线程不用自行创建,使用完毕不需要销毁线程,而是返回池中从而减少创建和销毁对象对CPU和内存的开销.
例如:线程池的概念类似人才资源中心,原本每次要运行一个线程(公司找一个员工)都必须去创建(培养)一个员工才行,有了线程池之后就在线程池中准备了多个创建好的线程(培训好的员工)等待被调用
1、不同请求之间重复利用线程,无需频繁的创建和销毁线程,降低系统开销;
2、控制线程数量上限,避免创建过多的线程耗尽进程内存空间,
3、能更好的控制线程的开启与回收,并且能定时执行任务。
1、 线程池由两个核心数据结构组成:
1)线程集合(workers):存放执行任务的线程,是一个HashSet;
2)任务等待队列(workQueue):存放等待线程池调度执行的任务,是一个阻塞式队列BlockingQueue;
2、任务由execute方法提交到线程池中调度,在提交任务时会有下面几种场景:
1)线程池中线程数量小于corePoolSize,此时任务不会进等待队列,线程池直接创建一个线程Worker执行提交的任务;
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。