为什么会出现线程池?
思考线程池问题时,我总是会和数据库连接池联想到一起,我个人觉得它们两者的核心思想有很大的相像之处,它们都是利用了一种"池化"的思想,目的都是为了减少连接的创建和销毁.
在多线程开发中,会因为线程数量多,而且很多时侯,每个线程仅仅执行一小段时间就会结束,所以我们需要频繁的创建线程,创建线程也是会消耗系统资源的,当需求很大时,有可能导致系统负载过重而直接崩溃掉.所以,我们就想要实现线程执行完后不用销毁,同时该线程还可以去执行其他任务,因此就出现了线程池。
线程池?
什么是线程池呢?通俗易懂的说法--线程池实际上就是线程的池子,基本思想还是一种对象池的思想,开辟一块内存空间,里面存放了很多未死亡的线程,池中线程执行调度由池管理器来处理。当有线程任务时,任务提交到线程池后,就会从线程池中直接寻找空闲的线程为之服务,执行完成后将线程对象归池,这样可以避免反复创建线程对象所带来的性能开销,节省了系统的资源。
在线程池的编程模式下,任务是提交给整个线程池,而不是直接交给某个线程,线程池在拿到任务后,它就会在线程池内部查找有无空闲的线程,然后再把任务交给线程池内部的某个空闲的线程,如果没有空闲的进程,任务就处于等待状态。
使用了线程池后减少了创建和销毁线程的次数,每个线程都可以被重复利用,可执行多个任务,同时我们可以根据系统的承受能力,调整线程池中线程的数目,可以很大程度的提高资源利用率.
线程池的好处?
1.避免线程的创建和销毁带来的性能开销。
2.避免大量的线程间因互相抢占系统资源导致的阻塞现象。
3.能够对线程进行简单的管理并提供定时执行、间隔执行等功能。