博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
发布一个 Linux 下的 C++ 多线程库
阅读量:6440 次
发布时间:2019-06-23

本文共 944 字,大约阅读时间需要 3 分钟。

发布一个我自己业余时间编写的 C++ 多线程库 for Linux,这个库只有不到 1000 行源代码,封装了 pthreads 的常用功能(互斥器、条件变量、线程),实现了简单的线程池,并仿照 java concurrent 包编写了 BlockingQueue 和 CountDownLatch。库里的每个 class 都提供了使用样例。

这个库的内容:

  • 整数的原子操作, AtomicInt32 和 AtomicInt64
  • 线程,Thread
  • 线程池,ThreadPool
  • 互斥器与条件变量, MutexLock,MutexLockGuard 与 Condition
  • 带调用栈信息 (stack trace) 的异常基类,Exception
  • 仿 Java concurrent 的 BlockingQueue 和 CountDownLatch
  • Singleton 与 ThreadLocal

注:我故意没有提供信号量 Semaphore 的封装。将来或许会增加读写锁的封装,如果我在博客中用到的话。

Thread 和 ThreadPool 的接口设计采用了《》里提倡的风格,没有使用继承和基类。

注意,CurrentThread 有一个 thread local 变量 t_threadName,其作用是在调试和分析 core dump 时打印线程的名称,例如:

(gdb) p 'muduo::CurrentThread::t_threadName' 

$4 = 0x4057fe "ThreadPool2"

MutexLock,MutexLockGuard 与 Condition 的使用请参考《》。

CountDownLatch 的使用样例见 test/BlockingQueue_test.cc

git 下载地址: 

浏览源代码: 

这个库在 Debian Squeeze 和 Ubuntu 10.04 LTS 下编译测试通过,适用于 x86 和 x86-64 平台。

    本文转自 陈硕  博客园博客,原文链接:http://www.cnblogs.com/Solstice/archive/2010/08/21/muduo_thread_lib.html
,如需转载请自行联系原作者
你可能感兴趣的文章
中国人工智能学会通讯——机器学习在商务智能中的创新应用
查看>>
昆腾升级DXi7500备份系统
查看>>
服务企业互联网化 打造社会化商业平台
查看>>
UC发布电影大数据 IP改编电影最受观众青睐
查看>>
人类已产生五十亿GB数据 X一代贡献的数据总量最大
查看>>
开源中国开源世界高峰论坛见证开源发展的11年
查看>>
如何用云计算改造“码农”?
查看>>
智能语音市场有多大? 阿里巴巴将如何破局后来者居上?
查看>>
Cisco Live 2017大会发布的5款热门物联网解决方案
查看>>
IDC:用技术推动城市的升级
查看>>
安全公司Carbon Black被指控泄漏TB级的客户数据,涉及多个全球1000强企业
查看>>
destoon分类树状列表
查看>>
白山云科技:首创“乐高式松耦合”架构 提供像拼积木一样的云分发服务
查看>>
Nutanix的超融合强在哪里?
查看>>
《并行计算的编程模型》一2.4.2 排序与内存模型
查看>>
西部数据发布业界首款2TB硬盘
查看>>
人工智能与存储大碰撞,到底是新需求还是零火花?
查看>>
开源大数据周刊-第68期
查看>>
解密新晋信息窃取木马Spymel
查看>>
国内首家! 迪普科技中标“中国移动2016年度负载均衡集中采购”
查看>>