草庐IT

atomic_set

全部标签

c++ - 为什么 Visual C++ 2015 允许 std::atomic 赋值?

几天前,我写了如下内容:structA{std::atomic_boolb=false;};使用VC++2015编译器在VisualStudio2015Update3中编译,没有弹出任何错误。现在我在Ubuntu上用GCC(5.4.0)重新编译了同样的东西并得到了错误:useofdeletedfunction'std::atomic::atomic(conststd::atomic&)我在ideone上遇到了同样的错误,设置为C++14(不确定它使用的是哪个编译器版本)。当然,将代码更改为以下内容可以解决gcc的问题:structA{std::atomic_boolb{false};}

C++0x |为什么 std::atomic 使用 volatile-qualifier 重载每个方法?

当前草案的以下摘录说明了我的意思:namespacestd{typedefstructatomic_bool{boolis_lock_free()constvolatile;boolis_lock_free()const;voidstore(bool,memory_order=memory_order_seq_cst)volatile;voidstore(bool,memory_order=memory_order_seq_cst);boolload(memory_order=memory_order_seq_cst)constvolatile;boolload(memory_orde

MySQL—约束:外键约束、语法(添加外键、删除外键)和删除/更新行为(CASCADE、SET NULL和图形化界面删除/更新)

版本说明当前版本号[20230406]。版本修改说明20230406初版本课程的笔记已经更新完毕,各位可以通过点击《黑马程序员MySQL数据库入门到精通,从mysql安装到mysql高级、mysql优化》学习笔记总目录查看所有知识点,同时也能免费下载学习笔记和思维导图。目录文章目录版本说明目录第四章约束4.1概述4.2约束演示用建表语句建表图形化界面建表4.3外键约束4.3.1介绍准备数据图表显示实验测试测试后的图表显示4.3.2语法1).添加外键1、创建表的时候直接添加2、表结构创建好后,额外地添加2).删除外键4.3.3删除/更新行为1).CASCADE2).SETNULL附:图形化界面删

c++ - std::unordered_set 中元素的要求

std::unordered_setmy_set;my_type必须满足哪些要求?(除了std::hash的特化) 最佳答案 您需要对std::hash进行专门化,并且需要定义一个运算符==来处理哈希冲突。编辑:您还应该确保您的类型具有复制构造函数(或让编译器为您生成一个),因为STL容器具有值语义。EDIT2:作为如何执行此操作的示例,您可以查看thisotherSOanswer. 关于c++-std::unordered_set中元素的要求,我们在StackOverflow上找到一个

c++ 11 std::atomic_flag,我使用正确吗?

我有一个简单的bool值,需要以线程安全的方式进行测试和设置。如果一个线程已经在工作,我希望第二个线程退出。如果我明白std::atomic_flag正确,这应该可以正常工作。但是,我不确定我是否正确理解了std::atomic_flag:)我似乎无法在网上找到很多简单的示例,除了这个自旋锁示例://myclass.cpp#usingnamespace//anonymousnamespace{std::atomic_flag_my_flag=ATOMIC_FLAG_INIT;}//nsmyclass::do_something(){if(!::_my_flag.test_and_set

c++ - 在 std::set 或 std::map 的键中使用 weak_ptr 是否安全

今天有很多关于std::weak_ptr和std::owner_less以及它们在关联容器std::set和std::map。有许多帖子指出在std::set中使用weak_ptr是不正确的,因为如果弱指针过期,它将是未定义的行为。这是正确的吗? 最佳答案 原因之一std::owner_lessexists是为了提供这种排序,并在存在过期弱指针的情况下保证其安全。我的逻辑是一、std::owner_less的定义operator()definesastrictweakorderingasdefinedin25.4undertheeq

c++ - 为什么 std::atomic 的 compare_exchange 会引用期望值?

std::atomic::compare_exchange_*的原因是什么?通过引用获取期望值,而不是通过值获取期望值? 最佳答案 如果操作失败,compare_exchange_*会将expected更改为实际值。它使循环更简单一些。 关于c++-为什么std::atomic的compare_exchange会引用期望值?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1998

c++ - 运行 boost bcp 工具时出错 : "The Boost path appears to have been incorrectly set"

尝试运行Boost的bcp工具时,出现以下错误:****exception(205):std::runtime_error:TheBoostpathappearstohavebeenincorrectlyset:couldnotfindboost/version.hppin********errorsdetected;seestandardoutputfordetails********错误消息与上面完全一样,它尝试搜索的路径为空。我尝试通过设置BOOST_ROOT环境变量来解决它,但同样的错误又回来了,搜索到的路径仍然是空的。系统为MacOSX10.9.1。

c++ - 如何根据 `std::vector` 中的元素对 `std::set` 进行切片

有没有一种根据std::set中的元素对std::vector进行切片的好方法?换句话说,std::set中的元素包含我想要在vector中的索引。当然,我可以用代码完成这个:#include#include#include#includetemplatestd::vectorslice(std::vectorconst&x,std::setconst&I){autoy=std::vector();for(autoconst&i:I)y.push_back(x[i]);returny;}intmain(){autox=std::vector{1.2,2.3,3.4,4.5,5.6};a

c++ - 为什么 std::atomic 在 Visual C++ 中不是简单的类型?

Folly库需要std::atomic应该是一个普通的类型。这适用于gcc和clang,但对于VisualC++即使对于std::atomic也是如此。.为什么std::is_trivial返回false?#include#includestatic_assert(std::is_trivial>::value,"std::atomicnottrivial"); 最佳答案 std::atomic曾经是微不足道的(这需要TriviallyCopyable),但现在不再是了。参见thisanswer以获得有关如何以及为何发生变化的详尽解