c++新特性之std::atomic
std::atomic为C++11封装的原子数据类型, 支持多种类型数据的原子操作,以下是atomic支持的数据类型,摘自http://www.cplusplus.com/reference/atomic/。
#include <atomic> #include <thread> #include <list> std::atomic_int g_iCount = 100; void threadfunc1() { while (g_iCount > 0) { printf("threadfunc1 g_iCount:%d\r\n", --g_iCount); } } void threadfunc2() { while (g_iCount > 0) { printf("threadfunc2 g_iCount:%d\r\n", --g_iCount); } } int main(int argc, char** argv) { thread t1(threadfunc1); thread t2(threadfunc1); thread t3(threadfunc2); thread t4(threadfunc2); t1.join(); t2.join(); t3.join(); t4.join(); return 0; }
以上初始化4线程,用来运行int类型的g_iCount的递减操作,未出现任何数据错误的情况。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2016-05-29 使用资源调控器管理资源
2016-05-29 SQL Server 2008新特性——策略管理
2016-05-29 导出SQL Server中所有Job的最简单方法
2016-05-29 SQL Server作业的备份
2016-05-29 Sqlserver 数据库
2016-05-29 SQLSERVER 数据库管理员的专用连接DAC
2014-05-29 基于sqlite的Qt 数据库封装