在我的代码中,我有一个从自定义类创建的对象的原子数组。简而言之,该类如下所示:

class myObj{
public:
    //some members here...

    //constructor
    myObj()noexcept{
        //some code here
    }

    //function I want to call
    void myFunc(){//some code here}
};
现在让我们说我有一个原子对象,而不是数组。我将在main.cpp中声明它,如下所示:
std::atomic<myObj> atomic_var;
我当然想(原子地)在上面的变量中存储一些东西。因此,我首先创建一个临时的myObj,然后在我的原子变量上调用.store()
myObj temp;
atomic_var.store(temp, std::memory_order_...);
现在的存储顺序无关紧要。
如上所述调用myObj::myFunc()时是否可以调用.store()
谢谢。

最佳答案

std::atomic<myObj>::is_lock_freefalse,因为myObj是用户定义的类型。这意味着std::atomic<myObj>是使用互斥锁实现的,但互斥锁未公开。
您可以做的是使互斥锁成为myObj的数据成员,并实现myObj& operator=(myObj const&)来锁定该互斥锁,执行其工作(例如,也称为myObj::myFunc()),然后解锁互斥锁。并使用myObj而不是std::atomic<myObj>
一种替代方法是实现std::atomic<myObj>的自定义完全特化,但这可能比它值得的工作更多。

09-05 22:49
查看更多