【问题标题】:`std::lock_guard` for `std::counting_semaphore` and `std::binary_semaphore``std::lock_guard` 用于 `std::counting_semaphore` 和 `std::binary_semaphore`
【发布时间】:2022-11-22 00:39:05
【问题描述】:

是否有标准提供的类似于std::lock_guardstd::scoped_lockstd::unique_lock的RAII守卫,我可以将其与std::binary_semaphorestd::counting_semaphore结合使用?

【问题讨论】:

  • 看起来目前还没有……也许他们会在下一个版本中添加类似的东西。

标签: c++ locking c++20 semaphore raii


【解决方案1】:

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;
}

【讨论】:

    【解决方案2】:

    您必须等到支持std::experimental::scope_exit。 然后你可以这样写:

    {
      m.acquire();
      auto guard = std::scope_exit([&]{m.release();});
      // other stuff...
    }
    

    在那之前,您将不得不从自定义实现中解决。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-09-18
      • 1970-01-01
      • 2013-12-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-03-28
      • 1970-01-01
      相关资源
      最近更新 更多