以下程序无法在VS11 beta,gcc 4.5或clang 3.1中构建
#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<int>&&
或const std::unique_ptr<int>&
吗? - André Caron