C++20 Atomic 原子 内存模型(二)

C++20 Atomic 原子 内存模型(二)

原子是C++内存模型的基础

强/弱内存模型

1. 强内存模型

Leslie Lamport 定义了顺序一致性的概念

顺序一致性提供两个保证:

  • 指令按源码的顺序执行
  • 对所有线程的所有指令有全局的顺序

以上不仅仅作用于原子, 也影响着非原子变量

image-20220807141634808

int main(int argc, char* argv[])
{atomic<int> x(0);atomic<int> y(0);atomic<int> res1(0);atomic<int> res2(0);std::jthread t1([&](){x.store(1);res1 = y.load();});std::jthread t2([&](){y.store(1);res2 = x.load();});//*this线程等待其他线程执行完成t1.join();t2.join();std::cout << "res1=" << res1 << std::endl;std::cout << "res2=" << res2 << std::endl;
}

多次运行:

image-20220807144504756

至少有一个值为 1, 表明每个线程都保证了顺序一致性, 但存在交替执行的情况

image-20220807144811635

2. 弱内存模型

使用弱内存模型这些指令会有更多意外的组合, 弱内存模型指令重排只保证单线程的相互依赖的的指令顺序正确

总结:

原子操作默认使用顺序一致性标志

image-20220807150153646

Atomic Flag

std::atomic_flag 是原子布尔类型。不同于所有 std::atomic 的特化,它保证是免锁的。不同于 std::atomic<bool>std::atomic_flag 不提供加载或存储操作。

ATOMIC_FLAG_INIT:定义能以语句 std::atomic_flag v = ATOMIC_FLAG_INIT; 用于初始化 std::atomic_flag 以清除(置 false )状态的初始化器。它能否用于其他初始化语境中是未指定的。

无锁原子

``std::is_always_lock_free`

在不同的平台上原子的实现可能不同, 可以使用std::is_always_lock_free来检查院子是如何实现的

if (std::atomic<T>::is_always_lock_free) assert(std::atomic<T>().is_lock_free();

自旋锁

自旋锁是一种基本的锁,比如互斥锁。

与互斥锁相比,不会等到得到锁。它不断地要求锁进入关键部分。它节省了从用户空间到内核空间的昂贵的上下文切换,但它完全利用CPU并浪费CPU周期。如果线程通常被阻塞短时间,自旋锁是相当有效的。

通常一个锁使用自旋锁和互斥锁的组合。锁首先在一个有限的时间段内使用自旋锁。如果没有成功,则使线程处于等待状态。

class Spinlock
{std::atomic_flag flag = ATOMIC_FLAG_INIT;
public:void lock(){while (flag.test_and_set());}void unlock(){flag.clear();}
};Spinlock spin;void workOnResource()
{spin.lock();spin.unlock();
}int main()
{std::thread t(workOnResource);std::thread t2(workOnResource);t.join();t2.join();
}

condition variable 与 std::atomic<bool>

环境变量

std::vector<int> myShareWork;
std::mutex mutex_;
std::condition_variable condVar;bool dataReady{false};void waitingForWork()
{std::cout << "working" << endl;std::unique_lock<std::mutex> lk(mutex_);condVar.wait(lk, [] { return dataReady; });myShareWork[1] = 2;std::cout << "Work done" << endl;
}void setDataReady()
{myShareWork = {1, 0, 3};{std::lock_guard<std::mutex> lk(mutex_);dataReady = true;}std::cout << "Data prepared" << endl;condVar.notify_one();
}int main(int argc, char* argv[])
{std::cout << std::endl;std::jthread t1(waitingForWork);std::jthread t2(setDataReady);t1.join();t2.join();for (auto v : myShareWork){std::cout << v << " ";}std::cout << "\n\n";
}

###使用std::atomic<bool>实现环境变量

std::vector<int> myShareWork;
std::atomic<bool> dataReady(false);void waitingForWork()
{std::cout << "waiting" << endl;while (!dataReady.load()){std::this_thread::sleep_for(std::chrono::milliseconds(5));}myShareWork[1] = 2;std::cout << "done" << endl;
}void setDataReady()
{myShareWork = {1, 0, 3};dataReady = true;std::cout << "Data prepared" << std::endl;
}int main()
{std::cout << std::endl;std::thread t1(waitingForWork);std::thread t2(setDataReady);t1.join();t2.join();for (auto v : myShareWork){std::cout << v << " ";}std::cout << "\n\n";
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407882.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IOS设计模式之二(门面模式,装饰器模式)

本文原文请见&#xff1a;http://www.raywenderlich.com/46988/ios-design-patterns.由 krq_tiger&#xff08;http://weibo.com/xmuzyq&#xff09;翻译&#xff0c;如果你发现有什么错误&#xff0c;请与我联系谢谢。门面&#xff08;Facade&#xff09;模式&#xff08;译者…

1.使用 Blazor 利用 ASP.NET Core 生成第一个 Web 应用

参考 https://dotnet.microsoft.com/zh-cn/learn/aspnet/blazor-tutorial/create 1.使用vs2022创建新项目 选择 C# -> Windows -> Blzxor Server 应用模板 2.项目名称BlazorApp下一步 3.选择 .NET6.0 或 .NET7.0 或 .NET8.0 创建 4.运行BlazorApp 5.全部选择是。 信…

BROCADE 300和MD3200扩展柜FC SAN,截图

这表示俺玩过&#xff0c;其实&#xff0c;这个光交换机在只有一个共享存储的情况下&#xff0c;可用可不用。 FC BROCADE只是为了方便后期扩展。 FC SAN之类的识别不靠IP&#xff0c;因为不是IP SAN嘛。但也是自己的识别体系。 转载于:https://www.cnblogs.com/aguncn/p/36640…

总算有点眉目了!

今天打开一个很久没用的邮箱~发现51CTO居然还记得我给我发了封邮件~我也很久没去了&#xff08;基本上注册过后就没去&#xff09;进去看了下~发现变化好大......壮大了。现在我有点激动&#xff0c;总算找到点眉目&#xff0c;在经过了2年的等死阶段&#xff08;偶于2005年学校…

C++ 20 并发编程 std::promise

C 20 并发编程 std::promise std::promise和std::future是一对, 通过它们可以进行更加灵活的任务控制 promise通过函数set_value()传入一个值, 异常, 或者通知, 并异步的获取结果 例子: void product(std::promise<int>&& intPromise, int a, int b) {intPro…

女孩儿们的那点秘密

女孩终归是女孩&#xff0c;女孩们总是强迫自己要出得了厅堂入得了厨房有木有&#xff1f;可你们造吗&#xff1f;这对女孩来说可都不容易&#xff01; 你们都以为做饭对女孩来说很简单&#xff0c;可知道我们面对四处乱喷热滚滚的油也会手足无措躲得远远的&#xff1f; 别嫌弃…

bootstrap学习笔记(一)网络系统

注&#xff1a;我是根据自己理解写的 有参考http://www.w3cschool.cc/bootstrap该教程。 bootstrap目前有两种默认的网络&#xff08;格&#xff09;系统&#xff1a;一个是940px,另一个是12列。 我们先从12列入手看看&#xff1a; 1.Bootstrap 使用 CSS 的 class "row&q…

委托笔记

刚写了段程序&#xff0c;总算稍微理解了下委托&#xff0c;留下备忘。 定义&#xff1a; 1 publicdelegatestringDelegateTest(stringsss);类中实例化委托&#xff1a; 1 publicclassTestClass2 {3 publiceventDelegateTest _delegateTest;4 5 publicstringBeginDelegate()6 {…

C++ 20 协程总结

C 20 协程总结 介绍 C 20提供的是非对称的、一等对象、无栈的协程&#xff08;Coroutines in C20 are asymmetric, first-class, and stackless&#xff09; 所谓协程&#xff0c;即用户级线程&#xff0c;一种用于将异步代码同步化的编程机制&#xff0c;使得程序的执行流可…

.net程序员的盲点(八):泛型

1.泛型介绍泛型类和泛型方法同时具备可重用性、类型安全和效率&#xff0c;这是非泛型类和非泛型方法无法具备的。泛型通常用在集合和在集合上运行的方法中。.NET Framework 2.0 版类库提供一个新的命名空间System.Collections.Generic&#xff0c;其中包含几个新的基于泛型的集…

Sublime Text 插件之常用20个插件

作为一个开发者你不可能没听说过 Sublime Text。不过你没听说过也没关系&#xff0c;下面让你明白。 Sublime Text是一款非常精巧的文本编辑器&#xff0c;适合编写代码、做笔记、写文章。它用户界面十分整洁&#xff0c;功能非同凡响&#xff0c;性能快得出奇。这些非常棒的特…

JUnit 4 与 JUnit 3

JUnit 是 Java? 语言事实上的 标准单元测试库。JUnit 4 是该库三年以来最具里程碑意义的一次发布。它的新特性主要是通过采用 Java 5 中的标记&#xff08;annotation&#xff09;而不是利用子类、反射或命名机制来识别测试&#xff0c;从而简化测试。在本文中&#xff0c;执着…

整合quickx到普通cocos2dx

quickx是对cocos2dx的lua扩展&#xff0c;它做了一些C的扩展&#xff0c;同时还在lua做了一些封装&#xff0c; 让用lua开发cocos2dx更快&#xff0c;中文站http://quick.cocoachina.com/。 由于现在的项目对cocos2dx有一些修改&#xff0c;又想用到quickx的便捷&#xff0c;于…

我的项目-财务系统

4 名称&#xff1a;财务管理系统 时间&#xff1a;2000 用时&#xff1a;3个月 vb6sqlserver7 独立完成 描述&#xff1a;包含凭证输入&#xff0c;审核&#xff0c;记帐&#xff0c;帐簿管理&#xff0c;自动转帐&#xff0c;会计报表等财务管理的整个流程。此项目在兖州…

对二维数组进行Zig-Zag扫描(C++)

对二维数组进行Zig-Zag扫描(C)&#xff0c;先自定义了一个类&#xff0c;类中有个函数Run()来实现这个扫描过程&#xff0c;二维数组是动态分配空间以及随机赋值的。 下图是Zig-Zag扫描方式&#xff1a; CZigZag.h: #include<iostream>using namespace std; typedef s…

Storing and Retrieving Images from SQL Server using Microsoft .NET

Storing and Retrieving Images from SQL Server using Microsoft .NET 原文 Storing and Retrieving Images from SQL Server using Microsoft .NET Download source - 19.6 KbIntroduction This article is about storing and retrieving images from database in Microsoft …