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

error C2248: 'std::promise<_Ty>::promise' : cannot access private member declared in class 'std::promise<_Ty>'

如何更正下面的代码以避免出现错误消息? 这段代码不应该工作吗? 是否可以使用不同的技术(packaged_task,异步)?

#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;
}

您在 gcc 和 clang 上的代码 compiles successfully(一旦包含缺失的 <algorithm> header)。由于这一行

,它在 MSVC 上失败
chunks_m.emplace_back(std::move(new_lower_chunk));

问题是 VS2013 和更早版本 do not implicitly generate a move constructor,所以 emplace_back 调用最终尝试复制构造一个 chunk_to_sort,它是 ill-formed 因为 std::promise 是 move-only.

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

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))
{}