标签:perfect-forwarding c c11 multithreading constructor
显然,可以将rvalue引用传递给std :: thread构造函数.我的问题是在cppreference中定义了这个构造函数.它说这个构造函数:
template< class Function, class... Args >
explicit thread( Function&& f, Args&&... args );
Creates new std::thread object and associates it with a thread of
execution. First the constructor copies/moves all arguments (both the
function object f and all args…) to thread-accessible storage as if
by the function:
template <class T>
typename decay<T>::type decay_copy(T&& v) {
return std::forward<T>(v);
}
据我所知:
std::is_same<int, std::decay<int&&>::type>::value
返回true.这意味着std :: decay< T> :: type将丢弃参数的rvalue引用部分.那么std :: thread构造函数如何知道lvalue或rvalue引用传递了哪个参数?因为所有的T&和T&&将通过std :: decay< T> :: type转换为T.
解决方法:
auto s = std::decay_copy(std::string("hello"));
相当于:
template<>
std::string std::decay_copy<std::string>(std::string&& src) {
return std::string(std::move(src));
}
std::string s = decay_copy<std::string>(std::string("hello"));
标签:perfect-forwarding,c,c11,multithreading,constructor 来源: https://codeday.me/bug/20191008/1873117.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。