**首先,ThreadPoolExecutor线程复用不是说可以随时想调用就调用!
举个例子:不启用线程池的话,一个任务(Runnable)对应一个线程(Thread)
去处理,这是最普通的做法,但是如果我们有100个任务呢?没错!那将会有100
个线程(Thread),每个线程只处理自身的任务。想想就害怕啊,你说一个四核
的某米最大并发线程数就是9个,同时开启100个线程会怎么样?分分钟让你感受
什么叫发烧。 这个例子里面最大的问题是因为每个线程只处理自身的任务!
但是如果每个线程可以处理很多任务呢?比如说线程A处理完任务1之后,发现
后面还有99个任务,那么继续处理任务2,线程能这样复用该多好!看到这里
你是不是突然就懂了?是的没错!ThreadPoolExecutor 就是干这个的!
ThreadPoolExecutor 里面如果规定了核心线程数最小5个的话,那么100个任务
应该每个线程处理20个左右!这就是线程复用!而不是线程调用!线程复用
不是说你随时想要就直接调用的,而是在处理高并发的时候可以尽可能的利用
线程工作,而不是每个线程只做自己的任务只做自己的事!
**