1.栈区(stack):程序运行时由编译器自动分配
存放:函数的参数值,局部变量的值。
存储连续,其操作方式类似于数据结构中的栈。
栈区处于相对较高的地址以地址的增长方向为上的话,栈地址是向下增长的,所以空间有限,windows下大多1-2M。
2.堆区(heap):
在内存开辟另一块存储区域。一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。
存放:程序员申请的内存空间。
存储不连续,数据结构中的堆是两回事,类似于链表,受限于虚拟内存,32bit系统可达到4G。
堆区是向上增长的用于分配程序员申请的内存空间。
3.全局区(静态区)(static)—编译器编译时即分配内存。
全局变量和静态变量的存储是放在一块的,
初始化的全局变量和静态变量在一块区域,
未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。
程序结束后由系统释放。
附:静态局部变量只对自己定义的函数体可见。
静态全局变量具有文件作用域,两个不同的源文件可以名字相同的静态全局变量,表示两个变量。
而全局变量定义的源文件需要用extern 关键字再次声明这个全局变量。
4.只读区
常量区:常量字符串就是放在这里的。程序结束后由系统释放。
程序代码区:存放函数体的二进制代码。
5.栈中的存储内容
栈: 在函数调用时进栈顺序
a.主函数中函数调用后的下一条指令(函数调用语句的下一条可执行语句)的地址
b.数的各个参数,在大多数的C编译器中,参数是由右往左入栈的
c.然后是函数中的局部变量。(注意静态变量是不入栈的,在全局区)。
出栈顺序,逆序。
6.堆的内容:堆的头部用一个字节存放堆的大小
record变量的首地址为0xc008 变量存储地址
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
考考你:根据结构体变量地址反推结构体首地址
最近在看《Linux内核设计与实现》这本书,感觉写得非常棒,看第6章《内核数据结构》的时候,遇到两个非常牛B的宏,据此简单地设计一个考题:根据一个结构体对象某成员的地址,计算出该结构体对象的首地址,你来试试?
结构体 偏移 container_of 首地址 offsetof