我似乎无法弄清楚为什么以下代码使用std :: thread进行编译, 但没有boost :: thread,在msvs 2015上会出现以下错误。
严重性代码描述项目文件行抑制状态 错误C2280'std :: future :: future(const std :: future&)': 试图引用已删除的功能
#include <thread>
#include <iostream>
#include <assert.h>
#include <chrono>
#include <future>
#include <boost/thread/thread.hpp>
void threadFunction(std::future<void> futureObj)
{
std::cout << "Thread Start" << std::endl;
while (futureObj.wait_for(std::chrono::milliseconds(1)) == std::future_status::timeout)
{
std::cout << "Doing Some Work" << std::endl;
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
}
std::cout << "Thread End" << std::endl;
}
int main()
{
// Create a std::promise object
std::promise<void> exitSignal;
//Fetch std::future object associated with promise
std::future<void> futureObj = exitSignal.get_future();
// Starting Thread & move the future object in lambda function by reference
std::thread th(&threadFunction, std::move(futureObj));
//boost::thread th(&threadFunction, std::move(futureObj));//this gives error
//Wait for 10 sec
std::this_thread::sleep_for(std::chrono::seconds(10));
std::cout << "Asking Thread to Stop" << std::endl;
//Set the value in promise
exitSignal.set_value();
//Wait for thread to join
th.join();
std::cout << "Exiting Main Function" << std::endl;
return 0;
}
答案 0 :(得分:1)
由于boost::thread
的{{1}}构造函数被指定为
好像
(function, args)
和thread(boost::bind(f,a1,a2,...))
复制参数而不是在调用基础函数时将其移动(因为它必须允许多次调用)。
为什么这样?可能是由于与向前移动的Boost.Thread版本向后兼容。
boost::bind
没有这种限制,并指定要移动参数。