考虑一个包含以下向量的类:
std::vector<std::tuple<double, double, double> > _data;
和以下成员函数:
inline double second(const unsigned int i) const
{
return std::get<1>(_data[i]);
}
我是否保证这个函数是线程安全的(注意我返回了一个双精度的副本)?
如果不是,这个函数的线程安全版本是什么?
考虑一个包含以下向量的类:
std::vector<std::tuple<double, double, double> > _data;
和以下成员函数:
inline double second(const unsigned int i) const
{
return std::get<1>(_data[i]);
}
我是否保证这个函数是线程安全的(注意我返回了一个双精度的副本)?
如果不是,这个函数的线程安全版本是什么?
std::vector
如果可以由另一个线程修改,则这不是线程安全的。为了使其线程安全,std::vector
必须同步对 的访问。一种可能的解决方案是引入 astd::mutex
并将其与std::vector
实例相关联。在这种情况下,std::mutex
将是包含 的类的成员变量std::vector
:
#include <mutex>
class X
{
private:
std::vector<std::tuple<double, double, double>> data_;
mutable std::mutex data_mutex_;
public:
double second(const unsigned int i) const
{
// Note that 'operator[]' is not bounds checked.
// Recommend adding a check to ensure 'i' is
// within range or use 'at()'.
std::lock_guard<std::mutex> lk(data_mutex_);
return std::get<1>(data_[i]);
}
};
请注意,添加std::mutex
使类不可复制,因为它本身是不可复制的。