程序内存分配:
1.栈区(stack):由编译器自动分配释放,存放为运行函数而分配的局部变量,函数参数,返回参数,返回地址。其操作方式类似于数据结构中的栈。
2.堆区(heap):一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。分配方式类似于链表。
3.全局数据区:存放全局变量,静态数据,常量。程序结束后由系统释放。
1).已初始化全局数据区 2).未初始化全局数据区
4.文字常量区:常量字符串就是放在这里的。程序结束后由系统释放。
5.程序代码区:存放函数体(类成员函数和全局函数)的二进制代码。
地址结果显示:
扫描二维码关注公众号,回复:
1055715 查看本文章
总结:内存中的地址由低到高依次是:代码区—>字符常量区—>已初始化全局数据区—>未初始化全局数据区—>堆区—>栈区,堆栈相对而生,堆中的地址逐渐增大,栈中的地址逐渐减小。(栈:先进后出,后进先出)