我必须删除吗?
Do I have to delete lambdas?
本文关键字:删除 更新时间:2023-10-16
我在动态分配对象中存储指向lambdas的指针:
struct Function {
SomeType*(*func)(int);
Function(SomeType*(*new_func)(int)):
func(new_func) {}
}
Function* myf = new Function(
[](int x){ return doSomething(x); }
);
delete myf;
我必须在这个类的析构函数中写一些特殊的东西吗?
不,您不需要做任何特别的事情。在这种情况下(您将lambda转换为函数指针),这与告诉您也不需要删除doSomething
没有什么不同。
更一般地说,lambdas是未命名的类型,删除了默认构造函数。这意味着您只能通过复制/移动构造它来显式地创建一个带有new表达式的表达式-只有这样您才能调用delete
。
N4140§5.1.2 [exp .prim.]λ)/20
与lambda表达式相关联的闭包类型已被删除默认构造函数和删除的拷贝赋值操作符。
如果不知道你的类应该做什么,就不可能告诉你它的析构函数应该做什么或不应该做什么。
如果类直接分配动态内存(使用new
或malloc
[不要使用malloc
]),那么您必须考虑如何释放该内存。同样,如果类获取了其他资源(如文件指针),则必须考虑如何释放这些资源。通常,正确的位置是析构函数。
问自己:类是否直接分配任何动态内存或获取外部资源?答案似乎是:不,没有。因此,在析构函数体中似乎没有什么特别需要显式完成的。
相关文章:
- 将数组的地址分配给变量并删除
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- C/C++编译器通常会删除重复的库吗
- 从链接列表c++中删除一个项目
- C++如何通过用户输入删除列表元素
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 是否需要删除包含对象的"pair"?
- 如何在自删除后将对象设置为nullptr
- 迭代时从向量和内存中删除对象
- 使用函数"remove"删除重复元素
- 如何从多映射中删除特定的重复项
- 运算符C++ "delete []"仅删除 2 个前值
- 删除指向指针的指针是运行时错误吗
- 将指针设置为"nullptr"并不能防止双重删除?
- 为什么示例代码访问IUnknown中已删除的内存
- 如何通过 getter 函数删除矢量的元素?
- 从控制台中删除最后打印的元素
- C++中的线程安全删除
- 如何从存储在std::映射中的std::集中删除元素
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数