错误C2248:'std :: promise <_Ty> :: promise':无法访问类'std :: promise <_Ty>'中声明的私有成员

use*_*810 2 c++ multithreading future promise c++11

如何更正以下代码以避免错误消息?这段代码不适用吗?是否有可以使用的不同技术(packaged_task,asynch)?

#include <list>
#include <future>

using namespace std;

template<typename T>
struct sorter
{
    struct chunk_to_sort
    {
        std::list<T> data_m;
        std::promise<std::list<T> > promise_m;
    };
    list<chunk_to_sort> chunks_m;
    void do_sort(std::list<T>& chunk_data)
    {
        std::list<T> result;
        result.splice(result.begin(),chunk_data,chunk_data.begin());
        T const& partition_val=*result.begin();
        typename std::list<T>::iterator divide_point = std::partition(chunk_data.begin(),chunk_data.end(),[&](T const& val){return val<partition_val;});
        chunk_to_sort new_lower_chunk;
        new_lower_chunk.data_m.splice(new_lower_chunk.data_m.end(), chunk_data,chunk_data.begin(),divide_point);
        chunks_m.emplace_back(std::move(new_lower_chunk));
    }
};

int main()
{
    sorter<int> s;
    list<int> l;
    l.push_back(4);
    l.push_back(3);
    s.do_sort(l);
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

Pra*_*ian 6

您的代码在gcc和clang上都成功编译(一旦包含缺少的<algorithm>标题).由于这条线,它在MSVC上失败了

chunks_m.emplace_back(std::move(new_lower_chunk));
Run Code Online (Sandbox Code Playgroud)

问题是VS2013和更早版本没有隐式生成移动构造函数,因此emplace_back调用最终会尝试复制构造错误chunk_to_sort,因为它std::promise是仅移动的.

要解决此问题,请提供移动构造函数定义(也可能是移动赋值运算符定义).

chunk_to_sort() = default;

chunk_to_sort(chunk_to_sort&& other)
: data_m(std::move(other.data_m))
, promise_m(std::move(other.promise_m))
{}
Run Code Online (Sandbox Code Playgroud)