标签:wrap base64 导致 detail div 表示 sel 动态 ffffff
接上篇,内存四区的分析-静态区,下面来说明一下堆区总结。
堆区分析:
堆区(heap):一般由程序员分配释放(动态内存申请与释放),若程序员不释放,程序结束时可能由操作系统回
就下面的程序:
1、先定义了一个指针变量tmp;那么此时在栈区会进栈 tmp,标识为①;
2、开始函数getMem的调用
3、然后再函数getMem中,首先定义一个指针变量p,标识为②
4、然后根据malloc开始申请内存空间,为128字节(白色表示),标识为③
5、然后将malloc返回的地址赋值给p,假设malloc返回的地址为0xaabb;则标识为④
6、因为变量p是在栈区,在函数getMem返回后,p被析构(灰色表示,但是在堆区的内存空间没有被析构),但是在函数getMem返回的是p的地址,所以讲p的地址赋值给tmp,标识为⑤
7、将字符串???????"aabbccdd"拷贝到tmp指向的内存空间,表示为⑥
关于函数strcpy的相关用法,详情查看:http://www.runoob.com/cprogramming/c-function-strcpy.html
但需要注意的是,strcpy拷贝字符串的时候并不包含结尾的’\0’。
相同功能的还有函数strncpy函数:http://www.runoob.com/cprogramming/c-function-strncpy.html
8、将字符串打印出来
9、释放先前申请的内存(灰色表示),归还给操作系统。
10、函数main返回,执行程序结束。
综上所述,可以得出其内存四区的效果为:
编译执行后的效果为:
注意:在用malloc申请内存后,如果后续这个内存不在使用,那应该是及时的将这个内存free掉,不然会引起内存泄漏。
内存泄漏也称作"存储渗漏",用动态存储分配函数动态开辟的空间,在使用完毕后未释放,结果导致一直占据该内存单元。直到程序结束。(其实说白了就是该内存空间使用完毕之后未回收)即所谓内存泄漏。
内存泄漏形象的比喻是"操作系统可提供给所有进程的存储空间正在被某个进程榨干",最终结果是程序运行时间越长,占用存储空间越来越多,最终用尽全部存储空间,整个系统崩溃。所以"内存泄漏"是从操作系统的角度来看的。这里的存储空间并不是指物理内存,而是指虚拟内存大小,这个虚拟内存大小取决于磁盘交换区设定的大小。由程序申请的一块内存,如果没有任何一个指针指向它,那么这块内存就泄漏了。
标签:wrap base64 导致 detail div 表示 sel 动态 ffffff
原文地址:https://www.cnblogs.com/songshuaiStudy/p/10653354.html