本文共 943 字,大约阅读时间需要 3 分钟。
发布一个我自己业余时间编写的 C++ 多线程库 for Linux,这个库只有不到 1000 行源代码,封装了 pthreads 的常用功能(互斥器、条件变量、线程),实现了简单的线程池,并仿照 java concurrent 包编写了 BlockingQueue 和 CountDownLatch。库里的每个 class 都提供了使用样例。
这个库的内容:
注:我故意没有提供信号量 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,如需转载请自行联系原作者