发布一个 Linux 下的 C++ 多线程库
2010-08-21 23:41
369 查看
发布一个我自己业余时间编写的 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 的接口设计采用了《以 boost::function 和 boost:bind 取代虚函数》里提倡的风格,没有使用继承和基类。
注意,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 下载地址: http://github.com/chenshuo/recipes
浏览源代码: http://github.com/chenshuo/recipes/tree/master/thread/
这个库在 Debian Squeeze 和 Ubuntu 10.04 LTS 下编译测试通过,适用于 x86 和 x86-64 平台。
这个库的内容:
整数的原子操作, AtomicInt32 和 AtomicInt64
线程,Thread
线程池,ThreadPool
互斥器与条件变量, MutexLock,MutexLockGuard 与 Condition
带调用栈信息 (stack trace) 的异常基类,Exception
仿 Java concurrent 的 BlockingQueue 和 CountDownLatch
Singleton 与 ThreadLocal
注:我故意没有提供信号量 Semaphore 的封装。将来或许会增加读写锁的封装,如果我在博客中用到的话。
Thread 和 ThreadPool 的接口设计采用了《以 boost::function 和 boost:bind 取代虚函数》里提倡的风格,没有使用继承和基类。
注意,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 下载地址: http://github.com/chenshuo/recipes
浏览源代码: http://github.com/chenshuo/recipes/tree/master/thread/
这个库在 Debian Squeeze 和 Ubuntu 10.04 LTS 下编译测试通过,适用于 x86 和 x86-64 平台。
相关文章推荐
- [C++] 发布一个 Linux 下的 C++ 多线程库
- 发布一个 Linux 下的 C++ 多线程库
- Linux -- 是一个操作系统,1991年由linus Torvalds发布的,核心是kernel版本号
- 发布一个基于 Reactor 模式的 C++ 网络库
- 在Linux平台下如何编译一个C++工程
- 一个linux c++的学习大纲
- 一个linux下c++程序
- 用c++创建一个Linux上的Daemon程序,含SHELL管理脚本(三)
- 让C/C++程序一次编译可以发布到多版本Linux之上
- WTL也发布了最新版,提供了一些vista界面的模板,对c++程序员有一个好消息!
- 在Linux下发布一个web项目的基本流程
- 让C/C++程序一次编译可以发布到多版本Linux之上
- Casablanca发布:一个用C++访问云的本地类库
- (原创)发布一个C++版本的ORM库SmartDB(一)
- Linux 内核一个大版本号 3.7 发布
- 发布一个基于 Reactor 模式的 C++ 网络库
- Linux使用Java将C++程序发布为webservice(wsdl)
- Linux下建一个C/C++库
- Casablanca发布:一个用C++访问云的本地类库
- 在Linux平台下如何编译一个C++工程