野指针,new/delete,malloc/free混用带来的后果
野指针:
野指针不是Null指针,是指向“垃圾”内存的指针。(一般是个乱码)
其内存空间被释放,但该指针的指向没有改变,仍然指向该片内存空间的首地址,若因失误而访问该指针的内存,进程就会报错崩溃。
野指针仍然指向原先的内存地址,而不是指向Null,所以用if(NULL == p)对野指针是没有作用的。
指针在创建的同时应该被初始化,要么设置为空,要么指向合法内存(已经被进程从堆空间或栈空间申请到的内存)。
野指针出现的原因:
1、指针变量未初始化。
2、指针被释放后未指向空。
3、指针操作超过了变量的生命周期,指向了临时变量
new/delete是对malloc/free的补充:
malloc/free是c/c++的标准库函数,
功能只有申请动态内存和释放内存。
new/delete是c++的运算符,
对于非内部对象,malloc/free无法满足其申请时调用构造函数,释放前调用析构函数的需求,故基于malloc/free加入自动调用构造函数和析构函数的功能封装了new/delete关键字,new/delete不是库函数,二是关键字。
混合使用new/delete和malloc/free会出现的问题:
它们的区别就在于前者会自动调用构造函数和析构函数,后者不具备这个功能。
如果new/free混合使用,就会因未调用对象析构函数而产生问题;
如果malloc/delete混合使用,就会因尝试调用析构函数出现问题,理论上讲程序不会出错,但可读性很差。
所以必须配对使用而非混合使用。