class Spin_lock
{
public:
Spin_lock( void );
void lock( void );
bool try_lock( void );
void unlock( void );
Spin_lock( const Spin_lock& ) = delete;
Spin_lock& operator = ( const Spin_lock& ) = delete;
private:
std::atomic<bool> d_atomic_bool;
};
Spin_lock::Spin_lock(){
d_atomic_bool.store( false, std::memory_order_relaxed );
return;
}
void Spin_lock::lock( void ){
while(d_atomic_bool.exchange( true, std::memory_order_acquire)){//@1独占缓存,使其他缓存失效,多cpu冲突剧烈(毛病).
while(1){
_mm_pause();//暂停指令延迟时间大约是12纳秒
if( !d_atomic_bool.load( std::memory_order_relaxed ) ) break;//关键.减少cas指令对内存总线影响.(锁释放时,断开<当>)该指令消耗资源极少,
//只读模式检查,只需要锁没被释放,就循环,
//这组旋转无竞争状态,不会对<内存,缓存>有影响,只要锁不释放,就不会争夺内存总线,大大提高效率
std::this_thread::yield(); // 在无其他线程等待执行的情况下,延迟时间113纳秒
// 在有其他线程等待执行情况下,将切换线程
if( !d_atomic_bool.load( std::memory_order_relaxed ) ) break;
continue;
}
continue;
}
return;
}
bool Spin_lock::try_lock( void )
{
return !d_atomic_bool.exchange( true, std::memory_order_acquire );
}
void Spin_lock::unlock( void )
{
d_atomic_bool.store( false, std::memory_order_release ); // 设置为false
return;
}
09-10
1344

05-03
109

05-02
173

05-02
280

05-02
93

04-27
429

04-18
289

04-11
222


2504d,12月会议
04-10
197


2025,倪五书的地址
04-01
166

03-28
247

03-26
98

03-25
207

03-20
118


2503d,d111更改
03-11
984

03-07
196


2503,D比C更易重构
03-04
340

02-26
238

02-22
196

02-13
172
