一、概要
spinLock的基本原理是如果发现其他人锁着,就一直循环,知道其他人解锁后,再上锁。一般SpinLock适用于锁的时间很短的情况,通过不断判定是否可以加锁,避免适用Mutex这类操作系统锁带来不能锁定时的上下文切换。
二、实现源码
#pragma once
#include <atomic>
#include <thread>
using namespace std;
class SpinLock
{
private:
atomic<bool> _flag;
public:
SpinLock()
{
_flag = false;
}
void lock()
{
bool r = false;
while (!_flag.compare_exchange_strong(r,<

本文介绍了SpinLock的基本原理,它适用于短暂锁定的情况,避免了上下文切换。通过分析源码,展示了如何利用Atomic进行原子操作,尤其是CAS(Compare and Swap)在保证并发安全性的同时提供高性能。实验结果显示,SpinLock成功实现了对spinCount的原子累加,性能优于传统的多线程非原子操作。
最低0.47元/天 解锁文章
1005





