动态分配内存与悬空指针

原创 2013年12月05日 20:45:42

                 int  F(int **P)

               {

                          int   a=10;

                         *P = &a;

                          return 0;

                 }              

              这是以前想过的一个问题:假如在F函数中中定义了一个自动变量a,然后有一个形参(**P),将*P指向这个a的地址。调用F函数的时候,系统会自动为这个变量a分配内存空间,它当然不会在程序的整个生命周期永久存在,在执行完F函数的时候,系统又会自动释放变量a的存储空间,那么指向a地址的指针*P怎么办?(注意,*P指针本身也是有内存空间的)

              原来*P变成了悬空指针。悬空指针是很危险的,它会指向一个无效的地址,如果它被一直放着不用还好,程序结束自然也结束。但是,万一它已成悬空指针,而在程序中又对它进行操作(比如读入新的数据),那潜在的危险性可大了,因为你不知道它指向了什么地址,万一指向的是系统的核心进程呢?可能导致系统崩溃!如果指向了其他硬件设备,如打印机啊,CPU方面的东西,那后果不堪设想。

              于是,我们可以动态来分配内存存储空间,例如使用malloc或realloc。

               *P = ((int *)malloc(sizeof(int )) == N ULL);

               这样的话,这个malloc分配存储空间会一直存在(除了在程序中显式释放),直到系统调用free函数的时候来释放。所以,就算前面的F函数执行完之后,这个存储空间还是存在的,但这个跟自动变量的自动分配存储空间是完全不同的,*P指向malloc分配的空间,不会再随便指向一个地址了。

               当然,动态内存分配也会带了内存泄漏的问题,有时候也会很严重,所以动态内存也不是随便分配的,需要统一的管理方法,比如数据结构实例,这是后话了……

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

二维指针动态分配内存连续问题分析

当我们定义一个二维指针时,如果需要存储相应的数据,就需要我们动态的分配内存,这时,有一点是需要注意的,分配内存的方法不同,内存的连续性也是不相同的,首先,博主先贴出测试代码:#include #in...

指针知识(四) 数组与指针、动态分配内存、指针函数与函数指针

一、指针常见错误解析 案例: #include #include //经典指针程序,互换两个数字 int main(void) { int i = 5; int *p; int *q...

你真懂动态分配内存吗?不是所有人能都做对这四道题......

废话少说,上程序 1、 void GetMemory(char *p) { p = (char *)malloc(100); } void Test(void) { char...

含动态分配内存的类的声明和定义以及继承

假设基类base,派生类derive1,derive2. 其中前2者含有指针成员(自动分配内存),后者不含。 1.声明          三者声明如下: #include"iostream" #in...

C++动态分配内存new delete

动态内存分配 1.堆内存分配 : C/C++定义了4个内存区间:代码区,全局变量与静态变量区,局部变量区即栈区,动态存储区,即堆(heap)区或自由存储区(free store)。 堆的概念...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)