4

我有一个需要审查的基本示例(C++)。

假设我有一个函数 PublicFunc(),还有一个叫做 PrivateFunc()。我想仔细同步它们。但是 PrivateFunc 有时也可以调用 PublicFunc,这意味着我们从同一个线程调用它。这会导致阻塞,我想解决它。

mutable boost::mutex m;

void PublicFunc() {
 m.lock();
 //Here it blocks, but why?
 //What I need is to get the lock if this func was called from PrivateFunc(), so exactly from the same thread.
 //But! It should definitely block on calling PublicFunc from outside while we are for example in the 'OtherPrivateFunc'.

 //Do some stuff

 //this is not necessary
 m.unlock(); 
}

void PrivateFunc() {
 m.lock();

 PublicFunc();

 OtherPrivateFunc();

 m.unlock();
}

boost 库中的哪个互斥锁或锁是正确的?谢谢!

4

1 回答 1

4

Amutex只能被锁定一次;任何在互斥锁被锁定时锁定互斥锁的调用都会阻塞,即使尝试锁定互斥锁是由持有互斥锁锁的线程进行的。

如果您希望能够在同一个线程上多次锁定互斥锁,请使用recursive_mutex.

或者,考虑重新组织您的代码,以便您拥有一组(私有)成员函数,假设互斥锁已锁定,并让所有其他函数委托给这些函数。这可以使代码更清晰,并且可以更容易地验证同步是否正确。

于 2012-07-07T21:54:00.550 回答