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-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享