std::generate_n 算法需要复制构造函数。如何在下面的代码中避免这种情况?
std::generate_n algorithm requires copying ctor. how to avoid this in code below?
std::vector<std::thread> thread_pool;
...
std::generate_n(std::back_inserter(thread_pool), cpu_cores,
[] (){
//...
return std::thread{worker(worker_name) };
} );
其中:
class worker {
std::atomic_bool done;
protected:
void operator()() {
while(!done) {
// some work
}
}
public:
worker(const std::string& worker_name)
: done(false) {
// some initialization
}
// other fields
};
error: use of deleted function 'std::atomic_bool::atomic_bool(const std::atomic_bool&)'
海湾合作委员会 4.9
据我所知,atomic 无法复制,只能移动。
上面的代码需要为 some_object class 复制 ctor。
如何解决这个问题?
(可能是设计本身比较差,
这里,some_object 是线程的仿函数,而 atomic 是关闭进程的标志)
你的class:
class worker {
std::atomic_bool done;
};
不可复制或移动,因为 std::atomic
显式 delete
是其复制构造函数(隐式 delete
是其移动构造函数)。如果你想让它被移动或复制,你必须自己写,例如:
worker(worker&& rhs)
: done(rhs.done.load())
{ }
std::vector<std::thread> thread_pool;
...
std::generate_n(std::back_inserter(thread_pool), cpu_cores,
[] (){
//...
return std::thread{worker(worker_name) };
} );
其中:
class worker {
std::atomic_bool done;
protected:
void operator()() {
while(!done) {
// some work
}
}
public:
worker(const std::string& worker_name)
: done(false) {
// some initialization
}
// other fields
};
error: use of deleted function 'std::atomic_bool::atomic_bool(const std::atomic_bool&)'
海湾合作委员会 4.9
据我所知,atomic 无法复制,只能移动。 上面的代码需要为 some_object class 复制 ctor。 如何解决这个问题?
(可能是设计本身比较差, 这里,some_object 是线程的仿函数,而 atomic 是关闭进程的标志)
你的class:
class worker {
std::atomic_bool done;
};
不可复制或移动,因为 std::atomic
显式 delete
是其复制构造函数(隐式 delete
是其移动构造函数)。如果你想让它被移动或复制,你必须自己写,例如:
worker(worker&& rhs)
: done(rhs.done.load())
{ }