x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
shared_mutex.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\thread\win32\shared_mutex.hpp
旋转
特效
属性
历史版本
#ifndef BOOST_THREAD_WIN32_SHARED_MUTEX_HPP #define BOOST_THREAD_WIN32_SHARED_MUTEX_HPP // (C) Copyright 2006-8 Anthony Williams // // Distributed under the Boost Software License, Version 1.0. (See // accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) #include
#include
#include
#include
#include
#include
#include
namespace boost { class shared_mutex: private boost::noncopyable { private: struct state_data { unsigned shared_count:11; unsigned shared_waiting:11; unsigned exclusive:1; unsigned upgrade:1; unsigned exclusive_waiting:7; unsigned exclusive_waiting_blocked:1; friend bool operator==(state_data const& lhs,state_data const& rhs) { return *reinterpret_cast
(&lhs)==*reinterpret_cast
(&rhs); } }; template
T interlocked_compare_exchange(T* target,T new_value,T comparand) { BOOST_STATIC_ASSERT(sizeof(T)==sizeof(long)); long const res=BOOST_INTERLOCKED_COMPARE_EXCHANGE(reinterpret_cast
(target), *reinterpret_cast
(&new_value), *reinterpret_cast
(&comparand)); return *reinterpret_cast
(&res); } state_data state; detail::win32::handle semaphores[2]; detail::win32::handle &unlock_sem; detail::win32::handle &exclusive_sem; detail::win32::handle upgrade_sem; void release_waiters(state_data old_state) { if(old_state.exclusive_waiting) { BOOST_VERIFY(detail::win32::ReleaseSemaphore(exclusive_sem,1,0)!=0); } if(old_state.shared_waiting || old_state.exclusive_waiting) { BOOST_VERIFY(detail::win32::ReleaseSemaphore(unlock_sem,old_state.shared_waiting + (old_state.exclusive_waiting?1:0),0)!=0); } } public: shared_mutex(): unlock_sem(semaphores[0]), exclusive_sem(semaphores[1]) { unlock_sem=detail::win32::create_anonymous_semaphore(0,LONG_MAX); exclusive_sem=detail::win32::create_anonymous_semaphore(0,LONG_MAX); upgrade_sem=detail::win32::create_anonymous_semaphore(0,LONG_MAX); state_data state_={0}; state=state_; } ~shared_mutex() { detail::win32::CloseHandle(upgrade_sem); detail::win32::CloseHandle(unlock_sem); detail::win32::CloseHandle(exclusive_sem); } bool try_lock_shared() { state_data old_state=state; do { state_data new_state=old_state; if(!new_state.exclusive && !new_state.exclusive_waiting_blocked) { ++new_state.shared_count; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif return !(old_state.exclusive| old_state.exclusive_waiting_blocked); } void lock_shared() { BOOST_VERIFY(timed_lock_shared(::boost::detail::get_system_time_sentinel())); } bool timed_lock_shared(boost::system_time const& wait_until) { #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true) #ifdef BOOST_MSVC #pragma warning(pop) #endif { state_data old_state=state; do { state_data new_state=old_state; if(new_state.exclusive || new_state.exclusive_waiting_blocked) { ++new_state.shared_waiting; } else { ++new_state.shared_count; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif if(!(old_state.exclusive| old_state.exclusive_waiting_blocked)) { return true; } unsigned long const res=detail::win32::WaitForSingleObject(unlock_sem,::boost::detail::get_milliseconds_until(wait_until)); if(res==detail::win32::timeout) { do { state_data new_state=old_state; if(new_state.exclusive || new_state.exclusive_waiting_blocked) { if(new_state.shared_waiting) { --new_state.shared_waiting; } } else { ++new_state.shared_count; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif if(!(old_state.exclusive| old_state.exclusive_waiting_blocked)) { return true; } return false; } BOOST_ASSERT(res==0); } } void unlock_shared() { state_data old_state=state; do { state_data new_state=old_state; bool const last_reader=!--new_state.shared_count; if(last_reader) { if(new_state.upgrade) { new_state.upgrade=false; new_state.exclusive=true; } else { if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=false; } new_state.shared_waiting=0; } } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { if(last_reader) { if(old_state.upgrade) { BOOST_VERIFY(detail::win32::ReleaseSemaphore(upgrade_sem,1,0)!=0); } else { release_waiters(old_state); } } break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif } void lock() { BOOST_VERIFY(timed_lock(::boost::detail::get_system_time_sentinel())); } bool timed_lock(boost::system_time const& wait_until) { #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true) #ifdef BOOST_MSVC #pragma warning(pop) #endif { state_data old_state=state; do { state_data new_state=old_state; if(new_state.shared_count || new_state.exclusive) { ++new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=true; } else { new_state.exclusive=true; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif if(!old_state.shared_count && !old_state.exclusive) { return true; } unsigned long const wait_res=detail::win32::WaitForMultipleObjects(2,semaphores,true,::boost::detail::get_milliseconds_until(wait_until)); if(wait_res==detail::win32::timeout) { do { state_data new_state=old_state; if(new_state.shared_count || new_state.exclusive) { if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; } } else { new_state.exclusive=true; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif if(!old_state.shared_count && !old_state.exclusive) { return true; } return false; } BOOST_ASSERT(wait_res<2); } } void unlock() { state_data old_state=state; do { state_data new_state=old_state; new_state.exclusive=false; if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=false; } new_state.shared_waiting=0; state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif release_waiters(old_state); } void lock_upgrade() { #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true) #ifdef BOOST_MSVC #pragma warning(pop) #endif { state_data old_state=state; do { state_data new_state=old_state; if(new_state.exclusive || new_state.exclusive_waiting_blocked || new_state.upgrade) { ++new_state.shared_waiting; } else { ++new_state.shared_count; new_state.upgrade=true; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif if(!(old_state.exclusive|| old_state.exclusive_waiting_blocked|| old_state.upgrade)) { return; } BOOST_VERIFY(!detail::win32::WaitForSingleObject(unlock_sem,detail::win32::infinite)); } } void unlock_upgrade() { state_data old_state=state; do { state_data new_state=old_state; new_state.upgrade=false; bool const last_reader=!--new_state.shared_count; if(last_reader) { if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=false; } new_state.shared_waiting=0; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { if(last_reader) { release_waiters(old_state); } break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif } void unlock_upgrade_and_lock() { state_data old_state=state; do { state_data new_state=old_state; bool const last_reader=!--new_state.shared_count; if(last_reader) { new_state.upgrade=false; new_state.exclusive=true; } state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { if(!last_reader) { BOOST_VERIFY(!detail::win32::WaitForSingleObject(upgrade_sem,detail::win32::infinite)); } break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif } void unlock_and_lock_upgrade() { state_data old_state=state; do { state_data new_state=old_state; new_state.exclusive=false; new_state.upgrade=true; ++new_state.shared_count; if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=false; } new_state.shared_waiting=0; state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif release_waiters(old_state); } void unlock_and_lock_shared() { state_data old_state=state; do { state_data new_state=old_state; new_state.exclusive=false; ++new_state.shared_count; if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=false; } new_state.shared_waiting=0; state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif release_waiters(old_state); } void unlock_upgrade_and_lock_shared() { state_data old_state=state; do { state_data new_state=old_state; new_state.upgrade=false; if(new_state.exclusive_waiting) { --new_state.exclusive_waiting; new_state.exclusive_waiting_blocked=false; } new_state.shared_waiting=0; state_data const current_state=interlocked_compare_exchange(&state,new_state,old_state); if(current_state==old_state) { break; } old_state=current_state; } #ifdef BOOST_MSVC #pragma warning(push) #pragma warning(disable:4127) #endif while(true); #ifdef BOOST_MSVC #pragma warning(pop) #endif release_waiters(old_state); } }; } #endif
shared_mutex.hpp
网页地址
文件地址
上一页
8/12
下一页
下载
( 19 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.