acl  3.5.3.0
thread_cond.hpp
浏览该文件的文档.
1 #pragma once
2 #include "../acl_cpp_define.hpp"
3 #include "noncopyable.hpp"
4 
5 #if !defined(_WIN32) && !defined(_WIN64)
6 # include <pthread.h>
7 # ifndef acl_pthread_cond_t
8 # define acl_pthread_cond_t pthread_cond_t
9 # endif
10 #else
11 struct acl_pthread_cond_t;
12 #endif
13 
14 namespace acl {
15 
16 class thread_mutex;
17 
18 /**
19  * 线程条件变量
20  */
22 {
23 public:
24  /**
25  * 构造方法
26  * @param mutex {thread_mutex*} 当该参数非 NULL 时,内部自动引用
27  * 该线程锁,否则,内部创建线程锁
28  */
29  thread_cond(thread_mutex* mutex = NULL);
30  ~thread_cond(void);
31 
32  /**
33  * 等待线程条件变量就绪
34  * @param microseconds {long long} 等待条件变量就绪的超时时间(微秒级)
35  * > 0 时表示等待超时的时间
36  * == 0,不等待
37  * < 0 则一直等待直到条件变量就绪
38  * @param locked {bool} 该参数表明是否已经将锁加锁,如果还未加锁,则
39  * 内部会先自动加锁,方法返回前再解锁;如果外部已经加锁,则内部不对
40  * 互斥锁做加锁/解锁处理
41  * @return {bool} 返回 true 表示条件变量就绪,否则表示超时或没被通知
42  */
43  bool wait(long long microseconds = -1, bool locked = false);
44 
45  /**
46  * 通知一个或几个等待在线程条件变量上的线程,表示条件变量就结
47  * @return {bool} 返回 false 表示通知失败
48  */
49  bool notify(void);
50 
51  /**
52  * 通知所有等待在线程条件变量上的线程,表示条件变量就结
53  * @return {bool} 返回 false 表示通知失败
54  */
55  bool notify_all(void);
56 
57  /**
58  * 获得与该线程条件变量绑定的线程互斥锁
59  * @return {thread_mutex&}
60  */
61  thread_mutex& get_mutex(void) const;
62 
63  /**
64  * 获得系统类型的线程条件变量对象
65  * @return {acl_pthread_cond_t*}
66  */
67  acl_pthread_cond_t* get_cond(void) const;
68 
69 private:
70  thread_mutex* mutex_;
71  thread_mutex* mutex_internal_;
72  acl_pthread_cond_t* cond_;
73 
74  bool block_wait(bool locked);
75  bool timed_wait(long long microseconds, bool locked);
76 };
77 
78 } // namespace acl
#define ACL_CPP_API