- 线程池是将线程和任务进行解耦,线程是线程,任务是任务,摆脱之前通过Thread创建线程的一个线程必须对应一个任务的限制。
- 线程池中,同一个线程可以通过从阻塞队列中不断获取新的任务来执行,核心的原理在于线程池对于Thread类进行了封装,并不是每次都会调用Thread.start()方法来创建线程,而是每次都让一个线程不断的循环的去执行任务。
- 线程池中的线程会不断的检查阻塞队列中是否有任务需要被执行。如果有就会立即执行,也就是调用任务中的run()方法。将run()方法当作一个普通的方法去执行,通过这种方式只能使用固定的线程将所有的run()方法串联起来。(任务没有直接写在线程池中的线程的run()方法里面,而是利用这些线程去调用任务的run()方法)。
- 多线程一般是继承任务类一般是继承Thread类或者实现Runnable接口,并把任务逻辑写在run()方法中,然后调用start()方法然后采用多线程的方式去执行。
- 但是线程池不是调用任务的start()方法来执行run()方法,而是每个线程执行循环任务,是直接调用run()方法,不是调用start()方法。
- 平时多线程的常识是一定不要run()方法,调用run()方法是同步运行的,调用start()方法是异步运行的,调用start()方法是创建子线程,
- 线程池如果调用start()方法意味着线程池里面创建了子线程,不是线程池的初衷。
- 线程池要同步运行,是直接调用run()方法,把run()方法当作普通方法执行。
线程池的复用原理
最新推荐文章于 2025-04-07 01:14:55 发布