std::atomic<int> 举例使用
时间: 2023-08-07 07:03:23 浏览: 52
下面是一个使用 std::atomic<int> 的示例代码:
```cpp
#include <iostream>
#include <thread>
#include <atomic>
std::atomic<int> counter(0);
void increment_counter() {
for (int i = 0; i < 1000000; ++i) {
++counter; // 自增操作会自动转换为原子操作
}
}
int main() {
std::thread t1(increment_counter);
std::thread t2(increment_counter);
t1.join();
t2.join();
std::cout << "Final counter value is " << counter << std::endl; // 原子地读取计数器的最终值
return 0;
}
```
在这个例子中,我们同样创建了一个 std::atomic<int> 类型的计数器,并在两个线程中并发地对它进行自增操作。由于 std::atomic<int> 已经重载了自增运算符,因此我们可以直接使用 ++counter 进行自增操作,它会自动转换为原子操作。最后,我们同样使用 counter 变量来读取计数器的最终值,并输出到控制台上。
相关问题
std::atomic<int>
std::atomic<int>是C++中的原子类型,用于现原子操作。它是一个模板类,可以用于对int类型的变量进行原子操作。 通过使用std::atomic<int>,我们可以确保对int类型的变量进行线程安全的操作。这意味着多个线程可以同时访问和修改这个变量,而不会导致数据竞争或其他并发问题。 这个类提供了一系列的成员函数,比如load()、store()、exchange()等,可以用于读取和修改原子变量的值。此外,std::atomic<int>还支持一些特殊的操作,如compare_exchange_strong()和compare_exchange_weak(),可以用于实现更复杂的原子操作。 引用[2]中提到的std::atomic<std::shared_ptr>和std::atomic<std::weak_ptr>是C++20新增的特化版本,用于对shared_ptr和weak_ptr进行原子操作。这些特化版本的std::atomic类型提供了对共享指针和弱指针的原子操作支持,可以更方便地在多线程环境下使用这些智能指针。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [c++ 11 原子操作库 (std::atomic)(一)](https://blog.csdn.net/qq_40788199/article/details/126879524)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
std::atomic<bool>使用例子
以下是一个使用std::atomic<bool>的例子:
```
#include <iostream>
#include <thread>
#include <atomic>
std::atomic<bool> flag(false); // 全局的std::atomic<bool>变量
void thread_func()
{
while (!flag.load()) // 检测flag的状态
{
// do something
}
std::cout << "thread_func exits." << std::endl;
}
int main()
{
std::thread t(thread_func); // 创建一个新线程
// do something
flag.store(true); // 线程退出时设置flag的状态
t.join(); // 等待子线程退出
std::cout << "main exits." << std::endl;
return 0;
}
```
在上面的例子中,我们创建了一个全局的std::atomic<bool>变量flag,并在主线程中设置了它的状态为true。在子线程中,我们不断地检测flag的状态,直到它的状态被设置为true,此时子线程会退出。通过使用std::atomic<bool>,我们可以保证在多线程环境下对flag变量的操作是原子的。