返回顶部
首页 > 资讯 > 操作系统 >Linux C下线程池有什么用
  • 400
分享到

Linux C下线程池有什么用

2023-06-15 15:06:14 400人浏览 安东尼
摘要

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

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

线程池也是多线程的处理方式。是将“生产者”线程提出任务添加到“任务队列”,然后一些线程自动完成“任务队列”上的任务。

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

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

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

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

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

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

Linux C下线程池有什么用

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

struct pthread_pool //线程池的实现 {  //一般会有如下成员   //互斥,用来保护这个“任务队列”  pthread_mutex_t lock; //互斥锁     //线程条件变量 表示“任务队列”是否有任务  pthread_cond_t cond; //条件变量    bool shutdown; //表示是否退出程序 bool:类型 false / true   //任务队列(链表),指向第一个需要指向的任务  //所有的线程都从任务链表中获取任务 "共享资源"  struct task * task_list;    //线程池中有多个线程,每一个线程都有tid, 需要一个数组去保存tid  pthread_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个线程,并且让线程去执行任务调配函数,  //记录所有线程的tid  int i = 0;  for(i = 0; i < threa_num; i++)  {   int ret = pthread_create(&(pool->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_create int add_threads(pthread_pool * pool, unsigned int num); {  //新创建num个线程,让每一个线程去执行线程调配函数    //将每一个新创建的线程tid,添加到pool-> tids  }  //如果任务少的时候,减少线程池中线程的数量 pthread_cancel join int 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, 需要一个数组去保存tid  pthread_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_create int add_threads(pthread_pool * pool, unsigned int num);   //如果任务少的时候,减少线程池中线程的数量 pthread_cancel join int remove_threads(pthread_pool * pool, unsigned int num);  #endif

感谢你能够认真阅读完这篇文章,希望小编分享的“Linux C下线程池有什么用”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网操作系统频道,更多相关知识等着你来学习!

--结束END--

本文标题: Linux C下线程池有什么用

本文链接: https://lsjlt.com/news/280783.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Linux C下线程池有什么用
    这篇文章主要介绍了Linux C下线程池有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。线程池也是多线程的处理方式。是将“生产者”线程提出任务添加到“任务队列”,然后一...
    99+
    2023-06-15
  • Python自带的线程池和进程池有什么用
    这篇文章主要介绍“Python自带的线程池和进程池有什么用”,在日常操作中,相信很多人在Python自带的线程池和进程池有什么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • Android中的线程和线程池有什么作用
    今天小编给大家分享一下Android中的线程和线程池有什么作用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言从用途上来说...
    99+
    2023-07-04
  • golang线程池和协程池有什么区别
    Golang中没有线程池的概念,而是通过协程(goroutine)来实现并发。协程是一种轻量级的线程,由Go语言的运行时环境(run...
    99+
    2023-10-26
    golang
  • 线程池是什么?线程池(ThreadPoolExecutor)使用详解
    点一点,了解更多https://www.csdn.net/ 本篇文章将详细讲解什么是线程池,线程池的参数介绍,线程池的工作流程,使用Executors创建常见的线程池~~~ 目录 点一点,了解更多 文章目录 一、线程池的概念 1.1线...
    99+
    2023-09-03
    java 数据结构 jvm 面试 java-ee
  • Linux如何实现C线程池
    这篇文章主要介绍了Linux如何实现C线程池,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。多线程编程,创建一个线程,指定去完成某一个任务,等待线程的退出。虽然能够满足编程需求...
    99+
    2023-06-28
  • python线程池有什么优点
    这篇文章给大家分享的是有关python线程池有什么优点的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其最初的设计是...
    99+
    2023-06-14
  • 如何分析Linux 下线程池的使用
    这期内容当中小编将会给大家带来有关如何分析Linux 下线程池的使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。处理多线程的方式可以采用线程池,可以将“生产者”线程提出任务列表添加到“任务列表”,然后一...
    99+
    2023-06-28
  • C#线程池ThreadPool怎么使用
    这篇文章主要讲解了“C#线程池ThreadPool怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#线程池ThreadPool怎么使用”吧!一、ThreadPool概述提供一个线程池...
    99+
    2023-07-02
  • Linux中如何实现C线程池
    这篇文章主要为大家展示了“Linux中如何实现C线程池”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中如何实现C线程池”这篇文章吧。Linux C线程池三个文件 1 tpoo...
    99+
    2023-06-09
  • 为什么要用线程池
    这篇文章主要讲解了“为什么要用线程池”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“为什么要用线程池”吧!下面是一段创建线程并运行的代码:for (int i =...
    99+
    2023-06-15
  • C#多线程之线程池ThreadPool用法
    目录一、ThreadPool1、QueueUserWorkItem()2、GetMaxThreads()3、GetMinThreads()4、SetMaxThreads()和SetM...
    99+
    2024-04-02
  • C#线程ParameterizedThreadStart有什么用
    ParameterizedThreadStart是一个委托,用于指定线程启动时要调用的方法,该方法带有一个Object类型的参数。使...
    99+
    2023-10-12
    C#
  • Linux C线程池简单实现实例
    Linux C线程池 三个文件 1 tpool.h typedef struct tpool_work { void (*routine)(void *); void ...
    99+
    2022-06-04
    线程 实例 简单
  • c++线程池实现的方法是什么
    C++线程池的实现方法可以使用C++中的多线程库,如std::thread和std::mutex等来实现。以下是一个简单的C++线程...
    99+
    2023-10-26
    c++
  • C++ 多线程编程中线程池的应用
    c++++ 多线程编程中使用线程池的好处包括:1)减少线程创建次数;2)负载均衡;3)避免资源争用。例如,通过使用线程池将图像转换任务分配给线程池,可以提高文件转换应用程序的转换速度。 ...
    99+
    2024-05-14
    多线程 线程池 c++ 标准库
  • 什么是java线程池
    使用线程池的好处有很多,比如节省系统资源的开销,节省创建和销毁线程的时间等,当我们需要处理的任务较多时,就可以使用线程池,可能还有很多用户不知道Java线程池如何使用?今天给大家分享Java四种线程池的使用方法。线程池介绍:线程池是一种多线...
    99+
    2017-06-28
    java入门 java 线程池
  • java线程池是什么
    java的线程池是什么,有哪些类型,作用分别是什么 (推荐学习:java课程)线程池是一种多线程处理形式,处理过程中将任务添加队列,然后在创建线程后自动启动这些任务,每个线程都使用默认的堆栈大小,以默认的优先级运行,并处...
    99+
    2016-06-22
    java教程 java
  • Android线程池是什么
    本篇内容主要讲解“Android线程池是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android线程池是什么”吧!我们都知道线程池的用法,一般就是先new一个ThreadPoolExec...
    99+
    2023-06-22
  • SpringBoot线程池和Java线程池怎么使用
    这篇文章主要介绍“SpringBoot线程池和Java线程池怎么使用”,在日常操作中,相信很多人在SpringBoot线程池和Java线程池怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringB...
    99+
    2023-07-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作