C/C++指针本身的内存占用及指向的内存问题(野指针等)
指针在声明的时候,会在栈上面给他分配一块内存
例如:
int *p
这个时候编译器在栈上面分配了一块空间出来用来存p的值,但是p的值目前并没有指向任何东西,这种时候得看编译器如何操作,有些编译器会随机分配一个p的值并且编译时不会报错,那么现在p就是所谓的“野指针”,使用起来会出现大问题。但有些编译器会直接在编译阶段就会报错,那么p会无法使用。
想使用这个p,有两种方法,一种是让他指向堆空间,一种是让他指向栈空间,例如:
指向栈空间:
int *p;
int a;
p = &a;
指向堆空间
int *p;
p = malloc();
其中指向堆空间的内存一定要自己进行释放,释放完之后并不是说在栈上的p的空间也没了,p还能继续使用,只是原本指向的那块堆空间被系统收了回去。
需要注意的一点是,p此时还指向着被释放掉的那一块地址,如果此时再调用p,则会出现野指针的问题,因此在释放内存的时候最好再将指针进行置空操作:
free(p);
p = NULL;
实际写代码时可以为了阅读方便撰写一个函数来进行释放,这个地方可以用一个指针的引用:
void releaseMemory(int *&p){
delete(p); // malloc的话就用free
p = nullptr;
}
int *p = new int();
releaseMemory(p);
程序实例调试,查看地址
程序如下:
void releaseMemory(int *&p) {
delete (p);
p = nullptr;
}
int main() {
int *p = new int();
delete (p);
p = new int();
releaseMemory(p);
return 0;
}
首先调试到内存申请过后 可以看到p此时的地址为0x1deacab1eb0
运行完delete过后 可以看到p仍然指向之前申请的地址且该地址的值已经不可用
再重新申请一块内存同时用releaseMemory来进行释放 p成功置为NULL,即便后续有调用也不会出现野指针的问题
|