• Java面试题:多线程面试必刷题,线程池是如何实现线程复用的?


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

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

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

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

    而线程池是属于线程的复用技术,因此对于这个问题,我把高手的回答整理到了一个15W字的面试文档里面,大家可以扫描文章尾端二维码领取。

    下面看看高手的回答

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

    高手:

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

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

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

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

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

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

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

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

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

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

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

    总结

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

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

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

    另外,我将所有Java面试系列制作成了完整的面试文档。它的便捷之处在于,可以通过检索的方式,找到你想要的面试题,目前已经更新180期,总计超过15W字!

    【想领取面试文档的小伙伴可以点击文章底部名片无套路免费赠送给大家!】

    需要高手面试文档面试文档的小伙伴可以扫描下方二维码
    ↓↓↓↓↓↓↓↓↓↓↓↓↓

  • 相关阅读:
    [GStreamer] 插件的名字要和GST_PLUGIN_DEFINE匹配
    7 种提升 Spring Boot 吞吐量神技
    典型海洋环境观测数据产品应用现状及对我国的启示
    数字信号处理-08-FIR IP应用实例
    kube-scheduler 抢占机制
    静态成员变量和成员函数
    【算法】排序——选择排序和交换排序(快速排序)
    递归法求二进制
    谈及区块链,我们脑海当中首先浮现出来的是,狂热、浮躁的场景
    滑动窗口算法
  • 原文地址:https://blog.csdn.net/q331464542/article/details/126489767