- C 标准库
- C 标准库
- C++ 标准库
- C++ 库 - 首页
- C++ 库 - <fstream>
- C++ 库 - <iomanip>
- C++ 库 - <ios>
- C++ 库 - <iosfwd>
- C++ 库 - <iostream>
- C++ 库 - <istream>
- C++ 库 - <ostream>
- C++ 库 - <sstream>
- C++ 库 - <streambuf>
- C++ 库 - <atomic>
- C++ 库 - <complex>
- C++ 库 - <exception>
- C++ 库 - <functional>
- C++ 库 - <limits>
- C++ 库 - <locale>
- C++ 库 - <memory>
- C++ 库 - <new>
- C++ 库 - <numeric>
- C++ 库 - <regex>
- C++ 库 - <stdexcept>
- C++ 库 - <string>
- C++ 库 - <thread>
- C++ 库 - <tuple>
- C++ 库 - <typeinfo>
- C++ 库 - <utility>
- C++ 库 - <valarray>
- C++ STL 库
- C++ 库 - <array>
- C++ 库 - <bitset>
- C++ 库 - <deque>
- C++ 库 - <forward_list>
- C++ 库 - <list>
- C++ 库 - <map>
- C++ 库 - <multimap>
- C++ 库 - <queue>
- C++ 库 - <priority_queue>
- C++ 库 - <set>
- C++ 库 - <stack>
- C++ 库 - <unordered_map>
- C++ 库 - <unordered_set>
- C++ 库 - <vector>
- C++ 库 - <algorithm>
- C++ 库 - <iterator>
- C++ 高级库
- C++ 库 - <any>
- C++ 库 - <barrier>
- C++ 库 - <bit>
- C++ 库 - <chrono>
- C++ 库 - <cinttypes>
- C++ 库 - <clocale>
- C++ 库 - <condition_variable>
- C++ 库 - <coroutine>
- C++ 库 - <cstdlib>
- C++ 库 - <cstring>
- C++ 库 - <cuchar>
- C++ 库 - <charconv>
- C++ 库 - <cfenv>
- C++ 库 - <cmath>
- C++ 库 - <ccomplex>
- C++ 库 - <expected>
- C++ 库 - <format>
- C++ 库 - <future>
- C++ 库 - <flat_set>
- C++ 库 - <flat_map>
- C++ 库 - <filesystem>
- C++ 库 - <generator>
- C++ 库 - <initializer_list>
- C++ 库 - <latch>
- C++ 库 - <memory_resource>
- C++ 库 - <mutex>
- C++ 库 - <mdspan>
- C++ 库 - <optional>
- C++ 库 - <print>
- C++ 库 - <ratio>
- C++ 库 - <scoped_allocator>
- C++ 库 - <semaphore>
- C++ 库 - <source_location>
- C++ 库 - <span>
- C++ 库 - <spanstream>
- C++ 库 - <stacktrace>
- C++ 库 - <stop_token>
- C++ 库 - <syncstream>
- C++ 库 - <system_error>
- C++ 库 - <string_view>
- C++ 库 - <stdatomic>
- C++ 库 - <variant>
- C++ STL 库速查表
- C++ STL - 速查表
C++ Atomic::store() 函数
C++ 的std::atomic::store()函数用于将原子变量的当前值替换为新值,确保没有其他线程可以中断此操作。store() 函数接受一个值和一个可选的内存顺序参数,该参数命令同步行为。
语法
以下是 std::atomic::store() 函数的语法。
void store (T val, memory_order sync = memory_order_seq_cst) volatile noexcept; void store (T val, memory_order sync = memory_order_seq_cst) noexcept;
参数
- val − 指示要复制到包含对象的的值。
- sync − 指示操作的同步模式。
返回值
此函数不返回任何内容。
异常
此成员函数从不抛出异常。
示例
在以下示例中,我们将考虑 store() 函数的基本用法。
#include <iostream> #include <atomic> int main() { std::atomic<int> a{0}; int x = 12; a.store(x); std::cout << "Stored value: " << a.load() << std::endl; return 0; }
输出
上述代码的输出如下:
Stored value: 12
示例
考虑以下示例,我们将使用带有 std::memory_order_relaxed 的 store() 函数。
#include <atomic> #include <iostream> int main() { std::atomic<int> a; int x = 7; a.store(x, std::memory_order_release); std::cout << "Stored value: " << a.load(std::memory_order_acquire) << std::endl; return 0; }
输出
以下是上述代码的输出:
Stored value: 7
示例
让我们来看下面的例子,其中 compare_exchange_strong 检查 x 是否等于 a。如果为真,则自动存储“b 值”。
#include <atomic> #include <iostream> int main() { std::atomic<char> x('A'); char a = 'A'; char b = 'B'; x.compare_exchange_strong(a, b); std::cout << "New value: " << x.load() << std::endl; return 0; }
输出
如果我们运行上述代码,它将生成以下输出:
New value: B
atomic.htm
广告