ACE_Recursive_Thread_Mutex实现了wrappe模式,该类的功能在于允许同一个线程内可递归的获取和释放mutex。
成员函数 1. ACE_Recursive_Thread_Mutex 调用函数ACE_OS::recursive_mutex_init初始化互斥量
说明:函数ACE_OS::recursive_mutex_init根据具体的操作系统分别调用ACE_OS::thread_mutex_init或者ACE_OS::thread_mutex_init和ACE_OS::cond_init初始化互斥量。 windows ACE_OS::thread_mutex_init Solaris9和AIX5.2 ACE_OS::thread_mutex_init ACE_OS::cond_init
说明:函数ACE_OS::thread_mutex_init根据具体操作系统分别调用InitializeCriticalSection (m)或者 ACE_OS::mutex_init初始化互斥量 windows InitializeCriticalSection Solaris9和AIX5.2 ACE_OS::mutex_init
说明:ACE_OS::mutex_init调用 操作系统 早期互斥量 早期sun mutex_init Solaris9和AIX5.2 pthread_mutexattr_init pthread_mutexattr_setpshared pthread_mutex_init pthread_mutexattr_destroy
说明:ACE_OS::cond_init调用 操作系统 早期互斥量 早期sun cond_init Solaris9和AIX5.2 pthread_cond_init
2. recursive_mutex_lock 调用函数ACE_OS:: thread_mutex_lock获取互斥量 调用函数ACE_OS:: thread_mutex_unlock释放互斥量 调用函数ACE_OS::cond_wait等待条件变量
3. recursive_mutex_lock 调用函数ACE_OS:: thread_mutex_lock获取互斥量 调用函数ACE_OS:: thread_mutex_unlock释放互斥量 调用函数ACE_OS::cond_signal释放条件变量
类成员变量 1. ACE_recursive_thread_mutex_t lock_;
2. int removed_;
类型说明 类型ACE_thread_mutex_t说明 各种操作系统的对应情况(OS_NS_Thread.h) 操作系统 早期互斥量 早期sun mutex_t windows CRITICAL_SECTION Solaris9和AIX5.2 pthread_mutex_t
类型ACE_recursive_thread_mutex_t说明 对于solaris和AIX来说pthread_mutex_t 并不支持递归申请,所以需要使用一套机制来模拟,对应类型ACE_recursive_thread_mutex_t是一个包括线程互斥量和条件变量的结 构。而Windows的CRITICAL_SECTION本身支持递归申请。
函数说明 函数thread_mutex_lock thread_mutex_lock函数调用EnterCriticalSection或者ACE_OS::mutex_lock进入互斥区。 windows EnterCriticalSection Solaris9和AIX5.2 ACE_OS::mutex_lock
说明:函数ACE_OS::mutex_lock根据具体操作系统调用不同函数获取互斥量 早期SUN mutex_lock Solaris9和AIX5.2 pthread_mutex_lock
转载请注明原文地址: https://ibbs.8miu.com/read-2170715.html