C++多进程工具-无锁线程安全栈

功能满足pop和push,可用移动构造函数,满足线程安全,利用利用单向链表和多线程原子变量原语compare_exchange_weak制成,效率略高于锁式栈,可能会有活锁风险,取决于处理机调度。可copy直接使用,环境为C++11及以上。

#pragma once
#include<atomic>
#include<iostream>
namespace safe_container {
	namespace no_mutex {
		template<class T>
		class stack {
		private:
			struct node {
				std::shared_ptr<T> data;
				std::shared_ptr<node> next;
				node():data(nullptr),next(nullptr){}
				node(T Data) :data(std::make_shared<T>(std::move(Data))), next(nullptr) {}
			};
			std::atomic<std::shared_ptr<node>> head;
		public:
			stack() :head(nullptr) {}
			void push(T data) {
				std::shared_ptr<node> new_node(std::make_shared<node>(std::move(data)));
				new_node->next = head.load();
				while (!(head.compare_exchange_weak(new_node->next,new_node)));
			}
			std::shared_ptr<T> pop() {
				std::shared_ptr<node> old_head = head.load();
				while (old_head && !head.compare_exchange_weak(old_head, old_head->next));
				return old_head ? old_head->data : nullptr;
			}
		};
	}
}

以上代码有个缺点是,代码中的std::shared_ptr不一定是无锁实现的,这取决于C++的库是怎么样的,当然可以自己写一个无锁的智能指针,原理并不难,这里就不展示了。如果不需要这么高的无锁并发特性,以上的代码也可以凑合着用了,比基本的有锁并发栈还是有一定程度提升的。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值