Why can#39;t C++11 move a noncopyable functor to a std::function?(为什么 C++11 不能将不可复制的函子移动到 std::function?)
问题描述
//------------------------------------------------------------------------------
struct A
{
A(){}
A(A&&){}
A& operator=(A&&){return *this;}
void operator()(){}
private:
A(const A&);
A& operator=(const A&);
int x;
};
//------------------------------------------------------------------------------
int main()
{
A a;
std::function<void()> func(std::move(a));
}
'A::A' : 不能访问类 'A' 中声明的私有成员
'A::A' : cannot access private member declared in class 'A'
似乎当我通过引用或 const
捕获某些内容时,我可以创建一个不可复制的 lambda.但是,当我这样做时,它实际上可以将它提供给 std::function
.
It seems like when I capture something by reference or const
I can make a non-copyable lambda. However when I do that it actually works to give it to a std::function
.
推荐答案
简短的回答是 C++11 规范要求您的 A
是 CopyConstructible
与 std::function
一起使用.
The short answer is that the C++11 specification requires your A
to be CopyConstructible
to be used with std::function
.
长的答案是这个要求存在是因为 std::function
在构造函数中删除了你的函子的类型.为此,std::function
必须通过虚函数访问函子的某些成员.其中包括调用运算符、复制构造函数和析构函数.由于这些是通过虚拟调用访问的,因此无论您是否实际使用 std::function
的复制构造函数、析构函数或调用运算符,它们都会被使用".
The long answer is this requirement exists because std::function
erases the type of your functor within the constructor. To do this, std::function
must access certain members of your functor via virtual functions. These include the call operator, the copy constructor and the destructor. And since these are accessed via a virtual call, they are "used" whether or not you actually use std::function
's copy constructor, destructor or call operator.
这篇关于为什么 C++11 不能将不可复制的函子移动到 std::function?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么 C++11 不能将不可复制的函子移动到 std::function?
- Stroustrup 的 Simple_window.h 2022-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- C++ 协变模板 2021-01-01
- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- 近似搜索的工作原理 2021-01-01
- 从python回调到c++的选项 2022-11-16
- 静态初始化顺序失败 2022-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- STL 中有 dereference_iterator 吗? 2022-01-01