十三诫增修--06:你不可以只做 malloc(), 而不做相应的 free().

楼主: wtchen (没有存在感的人)   2016-05-20 22:23:36
诫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
作者: johnjohnlin (嗯?)   2016-05-20 22:34:00
unique_ptr<int[]> 可以用在 new int[100]C++11 以前似乎不行
楼主: wtchen (没有存在感的人)   2016-05-20 22:37:00
我印象中unique_ptr是C++11开始才有的,之前只有auto_ptrauto_ptr在C++11似乎拿掉了?
作者: johnjohnlin (嗯?)   2016-05-20 22:47:00
auto_ptr 变成 deprecate 了auto_ptr 当 parameter,函数结束的时候就 free 掉了
作者: kwpn (ITSST)   2016-05-20 23:01:00
用unique_ptr<int[]>还不如用vector<int>
楼主: wtchen (没有存在感的人)   2016-05-20 23:16:00
我其实不是很懂unique_ptr的使用时机...
作者: LiloHuang (十年一刻)   2016-05-20 23:36:00
Smart Pointers (Modern C++) https://goo.gl/rCUn9Kunique_ptr, shared_ptr, weak_ptr 都有其使用时机如果今天只是要配置一个阵列,而没有要将其元素初始化使用 unique_ptr 搭配 custom deleter,就可以使用malloc 跟 free 来配置一块内存给 unique_ptr在数量级很大时,配置的内存能被自动回收又兼顾速度更常被用的是,像 file descriptor 或 socket FD 之类在 custom deleter 带自己想要的回收函式做一些事情第一个例子不好,因为 built-in type 也可省略初始化不一定要用 malloc 跟 free 还有 customer deleter像是 std::vector<int> 就无法省下初始化的动作了假设我想要当成一块 buffer 去给别人来填资料 XD而 3rd-party library 又只吃 int * 的场合之类的
作者: Clangpp (Clang++)   2016-05-21 10:36:00
动态阵列我建议用STL的容器 像vector之类的来做就好了effective STL有教你可以用vector 去填C风格的function只是你要知道里面会不会 重新allocate内存如果不会你就可以用 像是&v[0] 的方式 去填原来 pointer的参数

Links booklink

Contact Us: admin [ a t ] ucptt.com