在我的代码中,我有一个从自定义类创建的对象的原子数组。简而言之,该类如下所示:
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_free
是false
,因为myObj
是用户定义的类型。这意味着std::atomic<myObj>
是使用互斥锁实现的,但互斥锁未公开。
您可以做的是使互斥锁成为myObj
的数据成员,并实现myObj& operator=(myObj const&)
来锁定该互斥锁,执行其工作(例如,也称为myObj::myFunc()
),然后解锁互斥锁。并使用myObj
而不是std::atomic<myObj>
。
一种替代方法是实现std::atomic<myObj>
的自定义完全特化,但这可能比它值得的工作更多。