等待多个线程(Posix线程,c++)
Wait for multiple threads (Posix threads, c++)
考虑以下情况:
我有一个对象foo,它被多个线程使用,可能会或可能不会重复调用foo上的bar()方法。
bar()可以并行执行多次,因为它永远不会改变foo的状态。
问题出现时,我需要改变foo的状态从外部(从另一个线程,而不是从一个"工人"线程)-我怎么能锁定foo的方式,使调用线程块,直到最后一个工作线程是用bar()和所有的工作线程将阻塞在bar(),直到我再次释放foo ?
显然,在bar()的执行过程中,我不能只使用一个锁住的互斥锁,因为这样就没有并发性了。
任何想法?或者对于这类问题是否有更好的设计?
我不确定你将如何实现,没有工人使用foo来让作家更新它,但如果它不是一个问题,那么只需使用读写互锁(工人获得读锁,作家获得写锁)。
值得一提的是,您可能想要考虑使用foo Copy-on-Write。这样,您将使同步开销接近于零。您可以自动使用shared_ptr来实现这一点。
相关文章:
- 从不同线程使用int64的不同字节安全吗
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 在C++中使用cURL和多线程
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在cuda线程之间共享大量常量数据
- 如何将元素添加到数组的线程安全函数?
- 线程,如果else语句,都是错误的上下文切换后,会发生什么
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- Qt C++静态thread_local QNetworkAccessManager是线程应用程序的好选择吗
- 异常属于C++中的线程还是进程
- C++中的线程安全删除
- C++使用params创建线程函数会导致转换错误
- 类与私有变量的其他类之间的线程安全性
- CoInitialize()在单独的线程上崩溃而不返回
- c++中的线程池
- 线程之间的布尔停止信号
- 为什么std::async使用同一个线程运行函数
- 用于矢量处理的多个线程
- C++为线程工作动态地分割例程
- 为什么我不能在 while 循环中创建线程?