CAS原子操作
2022/2/27 23:54:04
本文主要是介绍CAS原子操作,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
void pop() { std::lock_guard<std::mutex>lock(mtx); if (base != NULL) { StackNode* q = base; base = q->next; &(q->data)->~T(); Freenode(q); cursize -= 1; } }
&(q->data)->~T();//类似于定位new
new的三种构建方式:
Testp=new Test(10)//申请空间 构建对象 返回对象地址 (在多核CPU上二三步骤可能错位)
Tests=(Test*)::operator new(sizeof(Test));//和malloc的最大区别就是,malloc在空间不足时,会返回一个NULL,而operator new会抛出一个异常
new(s)Test(10)//定位new,不管是malloc申请的,还是operator new来的,定位new都可在申请的空间中构建对象
在释放节点空间之前,必须将节点里边的对象析构掉(楼房拆迁前,必须把人员全都撤离)
改为原子操作:
完整代码:
#include<iostream> #include<thread> #include<mutex> #include<condition_variable> #include <semaphore> using namespace std; template<class T> class Stack { private: struct StackNode { T data; StackNode* next; }; StackNode* Buynode() { StackNode* s = (StackNode*)malloc(sizeof(StackNode)); if (NULL == s)exit(1); memset(s, 0, sizeof(StackNode)); return s; } void Freenode(StackNode* s) { free(s); } private: StackNode* base; size_t cursize; mutable std::atomic<StackNode*>pHead; Stack(const Stack&) = delete; Stack& operator=(const Stack&) = delete; public: Stack() :base(NULL), cursize(0) {} ~Stack() {} void Push(const T& val) { StackNode* newnode = Buynode(); new(&(newnode->data))T(val); //newnode->next = pHead; newnode->next = pHead.load(); while (!pHead.compare_exchange_weak(newnode->next, newnode)); //pHead = newnode; } }; void thread_funa(Stack<int>& s) { for (int i = 0; i < 10; i += 2) { cout << i << endl; s.Push(i); } } void thread_funb(Stack<int>& s) { for (int i = 1; i < 10; i += 2) { cout << i << endl; s.Push(i); } } int main() { Stack<int>ist; thread tha(thread_funa, std::ref(ist)); thread thb(thread_funb, std::ref(ist)); tha.join(); thb.join(); return 0; }
这篇关于CAS原子操作的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-01UniApp 中组件的生命周期是多少-icode9专业技术文章分享
- 2024-11-01如何使用Svg Sprite Icon简化网页图标管理
- 2024-10-31Excel数据导出课程:新手从入门到精通的实用教程
- 2024-10-31Excel数据导入课程:新手入门指南
- 2024-10-31RBAC的权限课程:新手入门教程
- 2024-10-31Svg Sprite Icon课程:新手入门必备指南
- 2024-10-31怎么配置 L2TP 允许多用户连接-icode9专业技术文章分享
- 2024-10-31怎么在FreeBSD上 安装 OpenResty-icode9专业技术文章分享
- 2024-10-31运行 modprobe l2tp_ppp 时收到“module not found”消息提醒是什么-icode9专业技术文章分享
- 2024-10-31FreeBSD的下载命令有哪些-icode9专业技术文章分享