下面的程序不会在VS11 beta制造,GCC 4.5,或3.1铿锵的std ::螺纹,可移动的,不可复制的参数
#include <thread>
#include <memory>
int main() {
std::unique_ptr<int> p;
std::thread th([](std::unique_ptr<int>) {
},std::move(p));
th.join();
}
这是因为参数类型是不可拷贝,但实现尝试复制它。
据我所知,这个程序是完好的,应该工作。对std :: thread的要求似乎意味着可移动的,不可复制的参数应该在这里工作。具体而言,它表示可调用对象和每个参数应满足MoveConstructible要求,且INVOKE(DECAY_COPY(std::forward<F>(f)),DECAY_COPY(std::forward<Args>(args))...)
应为有效表达式。
在这种情况下,我想表达出来的作品喜欢的东西:
template <class T> typename std::decay<T>::type decay_copy(T&& v)
{ return std::forward<T>(v); }
std::unique_ptr<int> p;
auto f = [](std::unique_ptr<int>) {};
decay_copy(f)(decay_copy(std::move(p)));
而且我不认为这应该涉及p
副本。 gcc至少可以编译这个表达式,尽管VS11没有。
- 我是否错误的要求和参数必须是可复制的?
- 对于实现复制参数,标准是否在这个问题上留有余地?
- 或者我尝试不符合?
您似乎通过复制传递线程参数(按照匿名函数签名)。参数类型不应该是'std :: unique_ptr &&'或'const std :: unique_ptr &'? –
2012-04-03 21:36:39
@安德烈:没有任何东西可以通过复制传递;通过_value_传递参数将根据调用者是传递左值还是右值来复制或移动。 – ildjarn 2012-04-03 21:47:22
@ildjarn:对不起,我的意思是“按价值”,而不是“通过复制”。它忽略了按值传递参数将选择移动构造函数(如果有)。 – 2012-04-03 22:23:49