快捷搜索:  汽车  科技

java面试题多线程的生命周期(多线程面试必刷题)

java面试题多线程的生命周期(多线程面试必刷题)生产者不断生产任务保存到容器,消费者不断从容器中消费任务。生产者消费者模型,其实就是通过一个中间容器来解耦生产者和消费者的任务处理过程。而线程池是属于线程的复用技术,因此对于这个问题,我把高手的回答整理到了一个15W字的面试文档里面,大家可以S我发送【Mic】领取。下面看看高手的回答线程池里面采用了生产者消费者的模式,来实现线程复用。

“线程池是如何实现线程复用的?”

一个工作2年的Java程序员,在面试互联网公司的时候被这个问题难住了。

大家好,我是Mic,一个工作了14年的Java程序员。

多线程是非常重要的一个技术领域,在实际开发中使用比较多。

而线程池是属于线程的复用技术,因此对于这个问题,我把高手的回答整理到了一个15W字的面试文档里面,大家可以S我发送【Mic】领取。

下面看看高手的回答

高手:

线程池里面采用了生产者消费者的模式,来实现线程复用。

生产者消费者模型,其实就是通过一个中间容器来解耦生产者和消费者的任务处理过程。

生产者不断生产任务保存到容器,消费者不断从容器中消费任务。

在线程池里面,因为需要保证工作线程的重复使用,并且这些线程应该是有任务的时候执行,没任务的时候等待并释放CPU资源。

因此,它使用了阻塞队列来实现这样一个需求。

提交任务到线程池里面的线程称为生产者线程,它不断往线程池里面传递任务。

这些任务会保存到线程池的阻塞队列里面。

然后线程池里面的工作线程不断从阻塞队列获取任务去执行。

java面试题多线程的生命周期(多线程面试必刷题)(1)

基于阻塞队列的特性,使得阻塞队列中如果没有任务的时候,这些工作线程就会阻塞等待。

直到又有新的任务进来,这些工作线程再次被唤醒。

从而达到线程复用的目的。

总结

基于阻塞队列实现的生产者消费者模型,是一个非常经典的模型。

它可以对两个不同业务进行解耦,还可以解决生产者和消费者的处理速度不匹配的问题。

建议大家可以去了解一下生产者消费者模型的底层实现,不管是基于wait/notify,还是基于condition.await/signal。

大家记得点赞、收藏加关注!

需要高手面试文档(附赠大厂内部十万字面试文档)或者有不懂的技术面试题想咨询的小伙伴可以后台私信【Mic】或者评论区留言。

java面试题多线程的生命周期(多线程面试必刷题)(2)

猜您喜欢: