背景
多线程的一个典型应用场景就是服务器的并发处理,如下图所示,多名用户向服务器发出数据操作的请求。为了提高并发性,我们可以在每收到一个用户请求时就创建一个线程处理相关操作。这种操作在请求数量较少时没有什么问题,但在请求数量很多时你会发现线程的创建和销毁所占用的系统耗时与资源已经对服务器的处理效率产生了不可忽视的影响。
对策
上述问题其实和内存的频繁分配释放相似,因此我们可以借鉴内存池的思想,构造一个线程池。基本思想就是提前创建一些工作线程,将加入的任务分配给它们做处理,并根据任务/线程的数量情况动态地增删线程,确保任务处理效率和系统资源占用之间达到比较好的平衡。
线程池技术框架如上图所示,具体来说包含如下关键点。
1)任务队列
线程池内部申请了一个任务队列,用于任务的存放与取出,一般