在sem_post(sem_t * sem)和sem_wait(sem_t * sem)之间是否存在完整的内存屏障?
Is there a full memory barrier around sem_post(sem_t * sem) and sem_wait(sem_t * sem)?
在linux代码中,我记得听说在mutex_lock()周围有一个完整的内存屏障。我想确定它是否也在sem_xxx周围
权威答案在这里:
http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap04.html tag_04_11
应用程序应确保多个控制线程(线程或进程)对任何内存位置的访问受到限制,这样当另一个控制线程可能正在修改内存位置时,任何控制线程都不能读取或修改内存位置。使用同步线程执行和同步相对于其他线程的内存的函数来限制这种访问。以下函数与其他线程同步内存:…
sem_wait
和sem_post
在列表中,因此它们是全内存屏障。
是的,它在无争用的情况下使用原子自增/自减,这当然有一个成员栏。对于争用的情况,有一个对futex的系统调用,它也有一个成员条。
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 在sem_post(sem_t * sem)和sem_wait(sem_t * sem)之间是否存在完整的内存屏障?