作者wtchen (没有存在感的人)
看板C_and_CPP
标题十三诫增修--06:你不可以只做 malloc(), 而不做相应的 free().
时间Fri May 20 22:23:36 2016
诫6加了unique_ptr的部份,我不是很熟,若是有误请指正。
===============================================================
06.
[C]你不可以只做 malloc(), 而不做相应的 free(). 否则会造成记忆体漏失
但若不是用 malloc() 所得到的记忆体,则不可以 free()。已经 free()了
所指记忆体的指标,在它指向另一块有效的动态分配得来的空间之前,不可
以再被 free(),也不可以提取(dereference)这个指标。
小技巧: 可在 free 之後将指标指到 NULL,free不会对空指标作用。
例:
int *p = malloc(sizeof(int));
free(p);
p = NULL;
free(p); // free不会对空指标有作用
=====================================================================
[C++] 你不可以只做 new, 而不做相应的 delete (除了unique_ptr以外)
注:new 与 delete 对应,new[] 与 delete[] 对应,
不可与malloc/free混用(结果不可预测)
切记,做了几次 new,就必须做几次 delete
小技巧: 可在 delete 之後将指标指到0或nullptr(C++11开始),
由於 delete 本身会先做检查,因此可以避免掉多次 delete 的错误
正确例子:
int *ptr = new int(99);
delete ptr;
ptr = nullptr;
delete ptr; /* delete 只会处理指向非 NULL 的指标 */
备注:
C++11後新增智能指标(smart pointer): unique_ptr
当unique_ptr所指物件消失时,会自动释放其记忆体,不需要delete。
例:
#include <memory> // 含unique_ptr的标头档
std::unique_ptr<int> p1(new int(5));
补充资料:
http://en.cppreference.com/w/cpp/memory/unique_ptr
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 223.140.52.193
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1463754219.A.14D.html
※ 编辑: wtchen (223.140.52.193), 05/20/2016 22:24:15
※ 编辑: wtchen (223.140.52.193), 05/20/2016 22:25:05
1F:推 johnjohnlin: unique_ptr<int[]> 可以用在 new int[100] 05/20 22:34
2F:→ johnjohnlin: C++11 以前似乎不行 05/20 22:34
3F:→ wtchen: 我印象中unique_ptr是C++11开始才有的,之前只有auto_ptr 05/20 22:37
4F:→ wtchen: auto_ptr在C++11似乎拿掉了? 05/20 22:37
5F:推 johnjohnlin: auto_ptr 变成 deprecate 了 05/20 22:47
6F:→ johnjohnlin: auto_ptr 当 parameter,函数结束的时候就 free 掉了 05/20 22:48
7F:推 kwpn: 用unique_ptr<int[]>还不如用vector<int> 05/20 23:01
8F:→ wtchen: 我其实不是很懂unique_ptr的使用时机... 05/20 23:16
10F:→ LiloHuang: unique_ptr, shared_ptr, weak_ptr 都有其使用时机 05/20 23:37
11F:→ LiloHuang: 如果今天只是要配置一个阵列,而没有要将其元素初始化 05/20 23:42
12F:→ LiloHuang: 使用 unique_ptr 搭配 custom deleter,就可以使用 05/20 23:44
13F:→ LiloHuang: malloc 跟 free 来配置一块记忆体给 unique_ptr 05/20 23:45
14F:→ LiloHuang: 在数量级很大时,配置的记忆体能被自动回收又兼顾速度 05/20 23:54
15F:→ LiloHuang: 更常被用的是,像 file descriptor 或 socket FD 之类 05/21 00:01
16F:→ LiloHuang: 在 custom deleter 带自己想要的回收函式做一些事情 05/21 00:02
17F:推 LiloHuang: 第一个例子不好,因为 built-in type 也可省略初始化 05/21 00:22
18F:→ LiloHuang: 不一定要用 malloc 跟 free 还有 customer deleter 05/21 00:22
19F:→ LiloHuang: 像是 std::vector<int> 就无法省下初始化的动作了 05/21 00:23
20F:→ LiloHuang: 假设我想要当成一块 buffer 去给别人来填资料 XD 05/21 00:28
21F:→ LiloHuang: 而 3rd-party library 又只吃 int * 的场合之类的 05/21 00:30
22F:→ Clangpp: 动态阵列我建议用STL的容器 像vector之类的来做就好了 05/21 10:36
23F:→ Clangpp: effective STL有教你可以用vector 去填C风格的function 05/21 10:37
24F:→ Clangpp: 只是你要知道里面会不会 重新allocate记忆体 05/21 10:38
25F:→ Clangpp: 如果不会你就可以用 像是&v[0] 的方式 去填原来 pointer 05/21 10:39
26F:→ Clangpp: 的参数 05/21 10:39