我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux如何实现C线程池

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux如何实现C线程池

这篇文章主要介绍了Linux如何实现C线程池,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

Linux如何实现C线程池

多线程编程,创建一个线程,指定去完成某一个任务,等待线程的退出。虽然能够满足编程需求,但是当我们需要创建大量的线程的时候,在创建过程以及销毁线程的过程中可能会消耗大量的CPU.增加很大开销。如:文件夹的copy、WEB服务器的响应。

线程池就是用来解决类似于这样的一个问题的,可以降低频繁地创建和销毁线程所带来地开销。

线程池技术思路:一般采用预创建线程技术,也就是提前把需要用线程先创建一定数目。这些线程提前创建好了之后,“任务队列”里面假设没有任务,那么就让这些线程休眠,一旦有任务,就唤醒线程去执行任务,任务执行完了,也不需要去销毁线程,直到当你想退出或者是关机时,这个时候,那么你调用销毁线程池地函数去销毁线程。

线程完成任务之后不会销毁,而是自动地执行下一个任务。而且,当任务有很多,你可以有函数接口去增加线程数量,当任务较少时,你可以有函数接口去销毁部分线程。

如果,创建和销毁线程的时间对比执行任务的时间可以忽略不计,那么我们在这种情况下面也就没有必要用线程池。

“任务队列”是一个共享资源“互斥访问”

Linux如何实现C线程池
简述Linux C下线程池的使用简述Linux C下线程池的使用

线程池本质上也是一个数据结构,需要一个结构体去描述它:

struct pthread_pool //线程池的实现{//一般会有如下成员//互斥锁,用来保护这个“任务队列”pthread_mutex_t lock; //互斥锁   //线程条件变量 表示“任务队列”是否有任务pthread_cond_t cond; //条件变量 bool shutdown; //表示是否退出程序 bool:类型 false / true//任务队列(链表),指向第一个需要指向的任务//所有的线程都从任务链表中获取任务 "共享资源"struct task * task_list; //线程池中有多个线程,每一个线程都有tid, 需要一个数组去保存tidpthread_t * tids; //malloc()   //线程池中正在服役的线程数,当前线程个数unsigned int active_threads; //线程池任务队列最大的任务数量unsigned int max_waiting_tasks; //线程池任务队列上当前有多少个任务unsigned int cur_waiting_tasks; //......};//任务队列(链表)上面的任务结点,只要能够描述好一个任务就可以了,//线程会不断地任务队列取任务struct task  //任务结点  {// 1. 任务结点表示的任务,“函数指针”指向任务要执行的函数(cp_file)void*(* do_task)(void * arg); //2. 指针,指向任务指向函数的参数(文件描述符)void * arg; //3. 任务结点类型的指针,指向下一个任务struct task * next;};

线程池框架代码如下,功能自填:

操作线程池所需要的函数接口:pthread_pool.c 、pthread_pool.h

把“线程池”想象成一个外包公司,你需要去完成的就是操作线程池所提供的函数接口。

pthread_pool.c

#include "pthread_pool.h"int init_pool(pthread_pool * pool , unsigned int threa_num){//初始化线程池的结构体 //初始化线程互斥锁pthread_mutex_init(&pool->lock, NULL); //初始化线程条件变量pthread_cond_init(&pool->cond, NULL);pool->shutdown = false ;// 不退出pool->task_list = (struct task*)malloc(sizeof(struct task));pool->tids = (pthread_t *)malloc(sizeof(pthread_t) * MAX_ACTIVE_THREADS);if(pool->task_list == NULL || pool->tids == NULL){ perror("malloc memery error"); return -1;}pool->task_list->next = NULL;//线程池中一开始初始化多少个线程来服役pool->active_threads = threa_num;//表示线程池中最多有多少个任务pool->max_waiting_tasks = MAX_WAITING_TASKS;//线程池中任务队列当前的任务数量pool->cur_waiting_tasks = 0;//创建thread_num个线程,并且让线程去执行任务调配函数,//记录所有线程的tidint i = 0;for(i = 0; i tids)[i], NULL, routine, (void*)pool); if(ret != 0) {  perror("create thread error");  return -1; } printf("[%lu]:[%s] ===> tids[%d]:[%lu]",pthread_self(),  __FUNCTION__, i , pool->tids[i]);}return 0;}void * routine(void * arg){//arg表示你的线程池的指针 while(){ //获取线程互斥锁,lock    //当线程池没有结束的时候,不断地从线程池的任务队列取下结点 //去执行。  //释放线程互斥锁,unlock  //释放任务结点}}int destroy_pool(pthread_pool * pool){//释放所有空间 等待任务执行完毕(join)。//唤醒所有线程//利用join函数回收每一个线程资源。}int add_task(pthread_pool *pool,void*(* do_task)(void * arg), void*arg){//把第二个参数和第三个参数封装成struct task   //再把它添加到 pool->task 任务队列中去 //注意任务队列是一个共享资源 //假如任务后要唤醒等待的线程。}//如果任务多的时候,往线程池中添加线程  pthread_createint add_threads(pthread_pool * pool, unsigned int num);{//新创建num个线程,让每一个线程去执行线程调配函数 //将每一个新创建的线程tid,添加到pool-> tids  }//如果任务少的时候,减少线程池中线程的数量 pthread_cancel joinint remove_threads(pthread_pool * pool, unsigned int num){//用pthread_cancel取消num个线程  //利用pthread_join函数去回收资源。}

pthread_pool.h

#ifndef __PTHREAD_POOL_H__#define __PTHREAD_POOL_H__//表示线程池中最多有多少个线程#define MAX_ACTIVE_THREADS 20//表示线程池中最多有多少个任务#define MAX_WAITING_TASKS 1024//任务队列(链表)上面的任务结点,只要能够描述好一个任务就可以了,//线程会不断地任务队列取任务struct task  //任务结点  {// 1. 任务结点表示的任务,“函数指针”指向任务要执行的函数(cp_file)void*(* do_task)(void * arg); //2. 指针,指向任务指向函数的参数(文件描述符)void * arg; //3. 任务结点类型的指针,指向下一个任务struct task * next;};struct pthread_pool //线程池的实现{//一般会有如下成员//互斥锁,用来保护这个“任务队列”pthread_mutex_t lock; //互斥锁   //线程条件变量 表示“任务队列”是否有任务pthread_cond_t cond; //条件变量 bool shutdown; //表示是否退出程序 bool:类型 false / true//任务队列(链表),指向第一个需要指向的任务//所有的线程都从任务链表中获取任务 "共享资源"struct task * task_list; //线程池中有多个线程,每一个线程都有tid, 需要一个数组去保存tidpthread_t * tids; //malloc()   //线程池中正在服役的线程数,当前线程个数unsigned int active_threads; //线程池任务队列最大的任务数量unsigned int max_waiting_tasks; //线程池任务队列上当前有多少个任务unsigned int cur_waiting_tasks; //......};int init_pool(pthread_pool * pool , unsigned int threa_num);void * routine(void * arg);int destroy_pool(pthread_pool * pool);int add_task(pthread_pool *pool,void*(* do_task)(void * arg), void*arg);//如果任务多的时候,往线程池中添加线程  pthread_createint add_threads(pthread_pool * pool, unsigned int num);//如果任务少的时候,减少线程池中线程的数量 pthread_cancel joinint remove_threads(pthread_pool * pool, unsigned int num);#endif

感谢你能够认真阅读完这篇文章,希望小编分享的“Linux如何实现C线程池”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux如何实现C线程池

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux如何实现C线程池

这篇文章主要介绍了Linux如何实现C线程池,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。多线程编程,创建一个线程,指定去完成某一个任务,等待线程的退出。虽然能够满足编程需求
2023-06-28

Linux中如何实现C线程池

这篇文章主要为大家展示了“Linux中如何实现C线程池”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中如何实现C线程池”这篇文章吧。Linux C线程池三个文件 1 tpool.hty
2023-06-09

Linux C线程池简单实现实例

Linux C线程池 三个文件 1 tpool.htypedef struct tpool_work { void (*routine)(void *); void *arg; struct tpool_work
2022-06-04

GO workPool的线程池如何实现

今天小编给大家分享一下GO workPool的线程池如何实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Go语言中的线程池
2023-07-05

C#如何通过线程池开启线程

小编给大家分享一下C#如何通过线程池开启线程,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!通过线程池开启线程 public static void Main(st
2023-06-17

如何实现java简单的线程池

这篇文章主要讲解了“如何实现java简单的线程池”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现java简单的线程池”吧!目录拆分实现流程实现方式1.拒绝策略2.阻塞队列3.线程池和工
2023-06-20

python实现线程池

什么是线程池?     诸如web服务器、数据库服务器、文件服务器和邮件服务器等许多服务器应用都面向处理来自某些远程来源的大量短小的任务。构建服务器应用程序的一个过于简单的模型是:每当一个请求到达就创建一个新的服务对象,然后在新的服务对象中
2023-01-31

Java如何使用线程池实现socket编程

这篇文章主要讲解了“Java如何使用线程池实现socket编程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java如何使用线程池实现socket编程”吧!前言以多个客户端和一个服务端的so
2023-06-29

linux如何查看线程池状态

在Linux中,可以使用以下命令来查看线程池的状态:1. 使用top命令:在终端中输入top命令后,可以查看系统中所有正在运行的线程以及其状态和资源占用情况。按下“Shift + H”键可以切换到线程模式,只显示线程信息。2. 使用ps命令
2023-08-24

Linux C下线程池有什么用

这篇文章主要介绍了Linux C下线程池有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。线程池也是多线程的处理方式。是将“生产者”线程提出任务添加到“任务队列”,然后一
2023-06-15

c++线程池实现的方法是什么

C++线程池的实现方法可以使用C++中的多线程库,如std::thread和std::mutex等来实现。以下是一个简单的C++线程池的实现方法:创建一个任务队列,用于存储需要执行的任务。创建一个固定数量的线程池,每个线程都在循环中从任务
2023-10-26

Java中线程池自定义如何实现

这篇“Java中线程池自定义如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java中线程池自定义如何实现”文章吧。线
2023-07-05

GOworkPool的线程池实现

本文主要介绍了GOworkPool的线程池实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-03-24

jdk线程池的实现

本文主要介绍了jdk线程池的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-14

C++如何实现对象池

这篇“C++如何实现对象池”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“C++如何实现对象池”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来就让我们进入主题吧。前言需求
2023-06-26

如何用Python实现线程池模型效果

今天就跟大家聊聊有关如何用Python实现线程池模型效果,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。本文提供给大家的是用python代码实现一个简单的线程效果源码案例。Python
2023-06-02

编程热搜

目录