如何删除存储在 std::forward_list 中的动态元素
How to delete dynamic elements stored in a std::forward_list
我在C++中使用std::forward_list来存储动态分配的元素。 我想知道"删除"列表中的元素或释放内存的正确方法是什么。
std::forward_list<int> integerList;
for (int i = 0; i < 5; i++) {
int* intPtr = new int(i);
integerList.push_front(*intPtr);
}
执行此代码后,我认为应该发生的是forward_list保存动态分配的 int。 现在,我将如何正确调用删除? 我注意到forward_list容器有一个 clear(( 函数,但它是否在每个节点中的所有元素上调用 delete?
我认为应该发生的是forward_list持有动态分配的 int
不,它不保存动态分配的int
。元素的类型是int
,当integerList.push_front(*intPtr);
时,值将被复制。
另一方面,你在 for 循环中得到内存泄漏,你需要delete
你new
编辑的内容。
for (int i = 0; i < 5; i++) {
int* intPtr = new int(i);
integerList.push_front(*intPtr);
delete intPtr;
}
如果要保存动态分配的元素,则应将元素的类型声明为指针,最后自行删除元素。
std::forward_list<int*> integerList;
for (int i = 0; i < 5; i++) {
int* intPtr = new int(i);
integerList.push_front(intPtr);
}
...
for (auto e : integerList) {
delete e;
}
您可以使用智能指针来避免这种内存管理,例如 std::unique_ptr
或 std::shared_ptr
.
是的,您必须遍历列表并调用 delete 每个指针元素。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- 如何在 C 中正确使用 libiconv 使其不会报告"Arg list too long"?
- C++中带有List类的迭代器Segfault
- 使用"std::unordereded_map"映射到"std::list"对象
- GCC对可能有效的代码抛出init list生存期警告
- 使用std::list创建循环链表
- 重载Singly Linked List中的赋值运算符
- 完美前进使用 std::forward vs RefRefCast
- '[](std::list& list)<int>{return std::move(list)}(list)' 是否保证将 'list' 留空?
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- 为什么这个 std::queue/指向结构的指针列表直到 List.Size() == 0 才释放内存?
- "std::list::splice(std::const_iterator pos, std::list&& other)"是否保证将"其他"留空?
- 从嵌套循环中的 std::list 中删除将返回访问冲突
- QStringList vs list<shared_ptr<QString>> 性能比较C++
- 包含 std::list 的结构体的 C++ 初始化
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- C++ assigment std::list:<typename>:itrator 在 main 中工作,但在方法中它不起作用
- 在基于范围的 for 循环期间插入 std::list 的后面
- 循环挂起迭代的 std::擦除 on std::list