zoukankan      html  css  js  c++  java
  • 半同步/半反应堆线程池

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
    本文链接:https://blog.csdn.net/LF_2016/article/details/72794814

    一、什么是线程池
    线程池是服务器预先创建的一组线程,这些线程运行着相同的代码,并具有相同的属性。当有新的任务到来的时候,主线程通过某种方式选择线程池中的某一个线程来为之服务,服务完之后又放回线程池中。

    二、为什么要有线程池
    相比于动态创建线程来说,线程池可以提高速度。因为线程的创建和销毁是需要时间的,如果我们预先创建好,用完之后再回收的话,则会节省不少时间。一般线程池中线程的数量和CPU的数量相差不多,不然的话会导致系统在线程间切换上花费不少时间。

    三、半同步/半反应堆线程池实现
    半同步/半反应堆线程池原理:
    这里写图片描述

    主线程和工作线程之间通过一个共享的工作队列来同步,工作线程睡眠在工作队列上。当有新的任务到来时,主线程将新的任务添加到工作队列中。这将唤醒正在等待任务的工作线程,不过只有一个工作线程会获得新任务的”接管权”,他可以从工作队列中取出任务并执行。而其他的工作线程则继续睡眠在工作队列上。
    由于主线程和工作线程之间有一个工作队列,所以主线程和工作线程之间没有耦合性,主线程往工作队列中插入任务,睡眠的工作线程通过竞争来取得任务并执行它。

    线程池源码

    四、实例
    实现线程池版本的web服务器:
    线程池版web服务器

    无欲则刚 关心则乱
  • 相关阅读:
    最难的事
    性格决定命运,习惯决定未来
    系统构架师之路
    时间是经不起浪费的
    如何投资自己,增加自身价值!
    最好的程序员大多是自学成才的
    杂记
    Win7启动Oracle出错
    推荐代码生成器工具排行
    Hibernate 与 Oracle 11g 的问题
  • 原文地址:https://www.cnblogs.com/xjyxp/p/11488895.html
Copyright © 2011-2022 走看看