等待多个线程(Posix线程,c++)

Wait for multiple threads (Posix threads, c++)

本文关键字:线程 c++ Posix 等待      更新时间:2023-10-16

考虑以下情况:

我有一个对象foo,它被多个线程使用,可能会或可能不会重复调用foo上的bar()方法。

bar()可以并行执行多次,因为它永远不会改变foo的状态。

问题出现时,我需要改变foo的状态从外部(从另一个线程,而不是从一个"工人"线程)-我怎么能锁定foo的方式,使调用线程块,直到最后一个工作线程是用bar()和所有的工作线程将阻塞在bar(),直到我再次释放foo ?

显然,在bar()的执行过程中,我不能只使用一个锁住的互斥锁,因为这样就没有并发性了。

任何想法?或者对于这类问题是否有更好的设计?

我不确定你将如何实现,没有工人使用foo来让作家更新它,但如果它不是一个问题,那么只需使用读写互锁(工人获得读锁,作家获得写锁)。

值得一提的是,您可能想要考虑使用foo Copy-on-Write。这样,您将使同步开销接近于零。您可以自动使用shared_ptr来实现这一点。