memory_order_acquire:保证所有之前的读操作完成,屏障之后的写操作不能重新排列到屏障之前,用于同步读取操作和后续的写操作。
memory_order_release:保证所有屏障之前的写操作完成,屏障之前的读操作不能重新排列到屏障之后,用于同步写入操作和前面的读操作。
memory_order_acq_rel:同时满足memory_order_acquire和memory_order_release的要求,用于同步读写操作。
memory_order_seq_cst:保证所有内存操作都符合顺序一致性模型,用于实现最严格的同步保障。
inline void MemoryBarrier() noexcept
{
std::atomic_thread_fence(std::memory_order_seq_cst);
}
template<typename T>
inline T VolatileRead(std::atomic<T>& v) {
return v.load(std::memory_order_acquire);
}
template<typename T>
inline T VolatileWrite(std::atomic<T>& v) {
return v.load(std::memory_order_release);
}
今天的文章C++ 11 轻松实现 C# Thread::MemoryBarrier、VolatileRead、VolatileWrite 内存屏障,用以控制内存顺序函数。分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/58835.html