SpinLock源码

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

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,<
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值