在C ++程序中,我有两个引用计数对象: King 和继承人。继承人需要阻止,直到国王被摧毁。 King是一个引用计数对象,当它的引用计数变为零时将被销毁。如果继承人持有对King的引用,则King的引用计数将永远不会为零。在King被摧毁之前,怎么能阻止继承人?
答案 0 :(得分:10)
您可以使用非拥有(或“弱”)引用,类似于how weak_ptr
works。
等到国王死了之后,你可以使用国王可以持有的互斥体,直到他去世并让继承人等待国王释放它。
如果你需要有多个继承人等待并且对继承人有一些顺序,你可以有一个“继承人选择器”对象来跟踪继承人名单及其优先顺序,以及国王何时释放互斥锁它会将该互斥锁的所有权分配给列表中的下一个继承人。
答案 1 :(得分:0)
谢谢@James。以下是我最终采用的解决方案:
互斥方法看起来很有希望,但是大多数互斥锁期望获取线程和释放线程是相同的。最后,我让Heir在堆栈上创建一个计数为零的信号量,将指针传递给信号量给King,释放King,然后尝试获取信号量。计数为零,所以继承人立即阻止。当调用King的析构函数时,它会调用信号量上的“释放”。这似乎适用于Rogue Wave信号量。