Linux(程序设计):66---简略版的线程池设计

Posted 董哥的黑板报

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux(程序设计):66---简略版的线程池设计相关的知识,希望对你有一定的参考价值。

一、设计线程池的优点、作用
  • 在前面的文章(javascript:void(0))中我们设计过了一种线程池,但是那种线程池比较复杂代码比较多,本文介绍一个简略版的线程池
  • 线程使应用能够更加充分合理的协调利用cpu 、内存、网络、i/o等系统资源。
  • 线程的创建需要开辟虚拟机栈,本地方法栈、程序计数器等线程私有的内存空间。
  • 在线程的销毁时需要回收这些系统资源。频繁的创建和销毁线程会浪费大量的系统资源,增加并发编程的风险。
  • 另外,在服务器负载过大的时候,如何让新的线程等待或者友好的拒绝服务?这些丢失线程自身无法解决的。所以需要通过线程池协调多个线程,并实现类似主次线程隔离、定时执行、周期执行等任务。
二、线程池的设计

  • 本线程池比较简单,就包括3个内容:

    • 任务节点。
    • 线程节点。
    • 线程池。
  • 任务节点:
    • 功能:就是一个任务,其有一个回调函数,用于执行任务。
    • 特点:当有新任务加入线程池之后,这个任务会被线程池分配给线程去处理。
//任务节点
typedef struct NJOB
{
    void (*_jobFunc)(void *NJOB); //回调函数
    void *_userData;              //回调函数参数

    struct NJOB *_next;
    struct NJOB *_prev;
}NJOB;
  • 线程节点:
    • 功能:单个线程的表示结构体,可以用来处理任务,
    • 特点:线程各自运行在自己的pthread_create()回调函数中,一直不间断的执行任务,
//线程节点
typedef struct NWORKER
{
    pthread_t _tid;                //线程节点的tid
    struct NWORKQUEUE *_workQueue; //该线程所属的线程池

    int _terminate;      //是否终止工作
    
    struct NWORKER *_next;
    struct NWORKER *_prev;
}NWORKER;
  • 线程池:线程池对象,保存着任务和所有的线程。
//线程池(管理着所有的任务和线程节点)
typedef struct NWORKQUEUE
{
    struct NJOB    *_jobs;
    struct NWORKER *_workers;

    int _sumWorkersNum;  //总共的线程数
    int _freeWorkersNum; //空闲的线程数
    
    pthread_mutex_t _mutex; //互斥锁
    pthread_cond_t  _cond;  //条件变量
}NWORKQUEUE;

typedef NWORKQUEUE threadPool;
三、编程实现
  • 源码下载方式:
    • CSDN下载:javascript:void(0)
    • 或者公众号【多栖技术控小董】回复【13740168】获取下载链接。

运行

  • 下载代码,进入目录之后输入make编译,然后运行即可

以上是关于Linux(程序设计):66---简略版的线程池设计的主要内容,如果未能解决你的问题,请参考以下文章

编写高质量代码改善C#程序的157个建议——建议66:正确捕获多线程中的异常

linux用户简略介绍

LVS简略介绍

redHat linux 修改防火墙设置简略版

《狂神说-JUC》

Linux基础汇总