版权声明:本文出自阿钟的博客转载请注明出处:/a_zhon/。
从打印结果看以看出,第一次打印的时候成功的改变了point的值当我们第二次打印得到的值却是0原因其实很简单,执行function()函数的改變了point的值当function()函数执行完毕的时候系统将函数内的变量回收掉了也就不存在了,i的地址就不存在了所以*point指向i的地址也就没有了
在function()函数中通过malloc(内存大小);函数向系统在堆内存中申请一块空间;返回一个地址值 当function()函数执行完毕的时候*temp指針变量在堆内存中所以不会被回收,所以*point指向的地址依旧存在
想要回收一個垃圾的时候可以调用free函数即可将内存释放 free(变量);
学的虽是计算机网络但是读的書很多也很杂也是一知半解,所以到现在我也不知道我有啥能力!只知道努力!
内存分配方式有三种:
1、从静态存储区域分配內存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在例如全局变量,static变量
2、在栈上创建。在执行函数时函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放栈内存分配运算内置于处理器的指令集中,效率很高但是分配的内存容量有限。
3、从堆上分配亦称动态内存分配。程序在运行的时候用malloc或new申请任意多少的内存程序员自己負责在何时用free或delete释放内存。动态内存的生存期由程序员决定使用非常灵活,但如果在堆上分配了空间就有责任回收它,否则运行的程序会出现内存泄漏频繁地分配和释放不同大小的堆空间将会产生堆内碎块。
你对这个回答的评价是
[1]从静态存储区域分配。内存在程序编译的时候就已经分配好这块内存在程序的整个运行期间都存在。例如全局变量static变量。
[2]在栈上创建在执行函数时,函数内局部变量的存储单元都可以在栈上创建函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中效率很高,但是分配的内存容量有限
[3]从堆上分配,亦称动态内存分配程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时鼡free或delete释放内存动态内存的生存期由程序员决定,使用非常灵活但如果在堆上分配了空间,就有责任回收它否则运行的程序会出现内存泄漏,频繁地分配和释放不同大小的堆空间将会产生堆内碎块
你对这个回答的评价是?
版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。