【发布时间】:2022-11-22 00:39:05
【问题描述】:
是否有标准提供的类似于std::lock_guard、std::scoped_lock或std::unique_lock的RAII守卫,我可以将其与std::binary_semaphore和std::counting_semaphore结合使用?
【问题讨论】:
-
看起来目前还没有……也许他们会在下一个版本中添加类似的东西。
标签: c++ locking c++20 semaphore raii
是否有标准提供的类似于std::lock_guard、std::scoped_lock或std::unique_lock的RAII守卫,我可以将其与std::binary_semaphore和std::counting_semaphore结合使用?
【问题讨论】:
标签: c++ locking c++20 semaphore raii
与 std::mutex 相比,std::counting_semaphore 的获取和释放调用可以发生在不同的线程上。所以,我认为在同一范围内锁定和解锁不是信号量的主要用例。但是,您可以像这样轻松创建自定义 lock_guard:
#include <semaphore>
#include <iostream>
template <typename T>
class custom_lock_guard
{
T &m_;
public:
custom_lock_guard(T &m) : m_(m)
{
m_.acquire();
std::cout << "Lock acquired" << std::endl;
}
~custom_lock_guard()
{
m_.release();
std::cout << "Lock released" << std::endl;
}
};
std::counting_semaphore<10> m(5);
std::binary_semaphore n(1);
int main()
{
custom_lock_guard g(m);
custom_lock_guard h(n);
return 0;
}
【讨论】:
您必须等到支持std::experimental::scope_exit。 然后你可以这样写:
{
m.acquire();
auto guard = std::scope_exit([&]{m.release();});
// other stuff...
}
在那之前,您将不得不从自定义实现中解决。
【讨论】: