多线程
文章平均质量分 82
jingqi_se
这个作者很懒,什么都没留下…
展开
-
跨平台中对于 信号量(semaphore) 的包装
信号量,常用于线程间同步。说明:跨平台宏(platform.hpp)的定义参见另一篇博文,当然截取代码实现时可以换成自己习惯的定义。跨平台中条件编译的使用使得代码不是那么容易看,但是还好每个函数只有一两句话windows/VC下使用系统API实现,其他情况下使用 pthread 提供的自旋锁 pthread_spinlock_t/** * @file - * @au原创 2013-11-02 14:39:57 · 1170 阅读 · 0 评论 -
跨平台中对于 自旋锁(spinlock) 的包装
以下代码在跨平台环境下包装了用户态自选锁(spinlock),支持以下平台: 操作系统linux、windows,编译器vc、gcc、mingw说明:跨平台宏(platform.hpp)的定义参见另一篇博文,当然截取代码实现时可以换成自己习惯的定义。跨平台中条件编译的使用使得代码不是那么容易看,但是还好每个函数只有一两句话自旋锁比互斥量轻量一些,适合使用在轻量任务的多线程同步中,会原创 2013-11-02 14:25:13 · 1788 阅读 · 0 评论 -
跨平台中对于 互斥量(mutex) 的包装
以下代码在跨平台环境下包装了互斥量(mutex),支持以下平台 linux/windows,vc/gcc/mingw/** * @file - * @author jingqi * @date 2010-7-9 */#ifndef ___HEADFILE___814FCD2E_2F65_4787_93E5_ECDE19588938_#define ___HEADFILE___原创 2013-11-02 13:44:57 · 1808 阅读 · 0 评论 -
java中无锁并发数组队列及其应用
在java中,无锁并发数据结构已经有一大堆了,例如,ConcurrentLinkedQueue、ConcurrentSkipListSet、ConcurrentSkipListMap、ConcurrentHashMap(ConcurrentHashMap实际上是有锁的,只是锁的粒度更小)等。但是在某个应用中,我需要一种无锁并发的数组容器,并且在容器生成时就指定容量,不需要动态扩展(以避免jvm原创 2013-11-02 17:31:37 · 3746 阅读 · 1 评论 -
跨平台中对于 条件量(condition) 的包装
说明:条件量(Condition)用于多线程同步,一个条件量常常与一个锁(windows下是临界区,linux下是pthread_mutex_t)同时使用跨平台宏(platform.hpp)的定义参见另一篇博文,当然截取代码实现时可以换成自己习惯的定义。跨平台中条件编译的使用使得其实现代码不是那么容易阅读,但是在使用这个包装类的时候就比较容易阅读了与条件量配合使用的锁类型 (跨平台代码原创 2013-11-02 14:49:01 · 908 阅读 · 0 评论