在Linux/Unix中有类似futex的功能吗
Are there any equivalents to the futex in Linux/Unix?
我正在寻找一些可以用于C/C++中轮询的东西(如select
、kqueue
、epoll
,即不忙于轮询
mutex
+condition variable
可以工作,但会有很多开销。futex
也可以,但它只适用于Linux(或者可能不适用?)。只要轮询本身正常工作,就不需要额外的同步,例如,当我在两个线程中调用wait
和wake
时,不需要竞争。
编辑:如果FreeBSD中不存在这样的"工具",如何创建一个具有C++11内置类型和系统调用的工具?
第2版:由于这个问题已经迁移到SO,我想让它更通用(不只是针对FreeBSD)
信号量不是互斥体,工作时开销略低(例如,避免互斥体+condvar重锁)
请注意,由于任何线程睡眠直到唤醒的解决方案都会涉及内核系统调用,因此它仍然不便宜。假设x86_64-glibc和FreeBSD-libc都是合理的实现,那么不可避免的代价似乎是:
- 计数的用户模式同步(使用CAS或类似设备)
- 等待队列和线程睡眠/等待的内核管理
我假设您担心的互斥锁+condvar开销是cond_wait->re-lock->unlock序列,这在这里确实避免了。
对于到线程之间的信号传递,需要信号量而不是互斥量。。
http://man7.org/linux/man-pages/man3/sem_wait.3.html
信号量可以像计数器一样使用,例如,如果您有一个队列,则每次插入消息时都会增加(post)信号量,而接收器则会为它取出的每一条消息减少(wait)信号量。如果计数器达到零,接收器将阻塞,直到有消息发布。
因此,一种典型的模式是将一个互斥对象和一个类似信号量的对象组合在一起;
sender:
mutex.lock
insert message in shared queue
mutex.unlock
semaphore.post
receiver:
semaphore.wait
mutex.lock
dequeue message from shared structure
mutex.unlock
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 如何找到锁定Linux futex的C++行
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 如何在Directwrite中获得给定字体的可用OpenType功能
- 对可变参数使用声明.如何选择正确的功能
- 询问在设计我的手臂模拟器功能表示格式1
- 在Linux/Unix中有类似futex的功能吗