当前位置:  技术问答>linux和unix

关于LINUX线程池的请教

    来源: 互联网  发布时间:2017-01-26

    本文导语:  线程池的技术从网上收罗到一大堆的文章,不过文章基本上都是点点滴滴、思路各有不同,不完整甚至不能保持思路正确。特来此求教各位线程池熟悉的高手: 1、 线程池的基础框架 2、 C++具体的框架流程 3、 逻...

线程池的技术从网上收罗到一大堆的文章,不过文章基本上都是点点滴滴、思路各有不同,不完整甚至不能保持思路正确。特来此求教各位线程池熟悉的高手:

1、 线程池的基础框架
2、 C++具体的框架流程
3、 逻辑架构

最好能给一个正统系统的思路,不要人云亦云不知所云。我是线程池菜鸟,系统学习中。

谢谢!

这里的两篇文章,我看过之后还是举得他讲的有些漏洞,有些地方也是一家之言。
Linux下通用线程池的创建与使用:
http://blog.sina.com.cn/s/blog_436fe8b10100rn7w.html
http://blog.sina.com.cn/s/blog_436fe8b10100rn7z.html

|
额... 你站的太高了, 必须仰望你了.

别让C++把自己给束缚了... 一开始就想这些就把人累死了...

1, 线程池就是一堆线程, 没任务就阻塞着.

2, 任务就是一个结构体, 内含数据, 以及处理数据的函数指针, 为了通用性, 大致写成这样:
struct task
{
    void *data; //数据
    int (*handler)(void *ctx); //处理数据
};

这样就把不同类型的任务抽象出来了, 用户指定方法, 提供数据就行了.

3, 任务的分派, 线程的管理. 这里就看需求了, 处理办法也很多样. 
①可以做任务队列(mutex+cond),让线程池去竞争。
②可以做事件驱动的, 也就是每个线程自己做select等待任务分发, 每个线程有自己的任务队列,这种方法控制更加简单灵活,可控性很强。

线程的管理方面工作不一定很复杂,可以在①的模型下外加一个变量来做控制, 也可以利用信号来做控制,都是摆脱不掉全局变量的互斥访问的, 尤其在线程控制这一块, 比进程控制要麻烦的多。

线程退出与否,没有办法获得,不像进程那样调用一个非阻塞的waitpid试探一下就可以了,一旦没有线程退出而调用了pthread_join就会阻塞,而且join没法被信号中断, 也就没法设计setitime来按周期中断阻塞,所以必须维护全局信息来记录线程的退出状况,控制线程必须定期轮询,这是目前web服务器必然的设计方式,也就是控制线程必须轮询,不可能有一种方法达到完全的异步。

线程池管理比较简单灵活可控的是方法②,按照我的想法是完全可以异步的,主控线程和线程池完全的异步,主控线程当然也需要轮询,目的是及时跟进线程池状态,以便进行线程数量控制。

我前几天还写过一个进程控制框架,可以简单的看一下:

http://www.cnblogs.com/owenliang/       


|
...菜鸟觉得很复杂, 我这种小鸟觉得线程池没什么难度..想咋整就咋整.

|
这个没什么说的... 什么需求做成什么样...

|
你有什么设计想法说出来讨论讨论得了.

    
 
 

您可能感兴趣的文章:

  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 求个linux多线程编程的例子,要有线程池的 通用些更好
  • 请问Linux下线程开销为什么这么大?一个线程要占用近10M内存
  • Linux多线程时一些线程分不到时间片
  • 说说windows线程和linux线程的区别?
  • linux 下多线程 每个线程能否使用alarm来处理,信号是否会乱呢?
  • linux下,如何在多线程中每个线程设置一个定时器,在线等,急。。。谢谢
  • 在创建linux线程时为什么会多一个线程?
  • linux如何主动将线程放入到线程调度队列中重新排队?
  • 在linux RH73下为什么单进程只能开1021个线程线程.
  • Linux下如何让主线程挂起一个指定的时间段而子线程继续运行?谢谢
  • LINUX下有没有线程概念,和WIN下线程概念有什么不同,谢谢.
  • linux线程编程问题
  • linux线程最大数,奇怪,怎么只有300?而且线程是用完就没了,不是同时300啊!
  • 跪求:linux下pthread 双线程计算和单线程的运行时间完全相同是为什么?
  • linux线程与进程的问题
  • linux 下子线程不能执行的问题?
  • linux多线程编程的问题
  • linux多线程编程
  • 请教Linux下pgadmin3-1.0.2的编译和安装!!高分请教!
  • 各位大虾,请教装了REDHAT9操作系统后,启动时无法引导到LINUX,请教该如何解决啊
  • 向linux达人请教linux下5.1声道测试工具
  • 请教一下,如果想在linux下开发java,选哪个版本的linux好一点
  • 小弟想请教,如果现在不像装linux了怎样把linux的分区改回ntfs格式的?
  • 请教:linux启动盘和一张盘的linux有何区别?
  • 请教linux高手,在Linux
  • 在linux下面怎么安程序啊?我刚裝了一个 linux,下了一个迅雷安装程序,可是不知道怎么安装啊?真心请教。
  • 初次接触linux,关于linux 用户权限问题请教!
  • 请教linux 下的adsl拨号问题.
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在没有linux的盘,只有DOS启动盘)
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • 如何让win2000和linux共存。我装好WIN2000,再装LINUX7.0,但LILO只能找到LINUX,不能引导WIN2000
  • linux c下利用srand和rand函数生成随机字符串
  • 在windows中的VMware装了个linux,主板有两个串口,能做windows和linux的串口通信测试么,怎么测试这两个串口在linux是有效
  • Linux c++虚函数(virtual function)简单用法示例代码
  • 我们网站的服务器从windows2000迁往linux,ASP程序继续使用,可是我连LINUX的皮毛都不了解,大家告诉我LINUX下怎么建网站??
  • Docker官方镜像将会使用Alpine Linux替换Ubuntu
  • 中文Linux与西文Linus分别哪一个版是权威?I认为是:中科软的白旗Linux与西文的绿帽子Linux!大家的看法呢?
  • Linux下chmod命令详细介绍及用法举例
  • 我重装了winme,却进不了Linux了,而我现在又没有Linux光盘,也没有Linux启动盘,还有没有办法?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3