- 1. 内存分区模型
- 1.1 程序运行前
- 1.2 程序运行后
内存分区模型的主要知识结构:
1. 内存分区模型
C++程序在执行时,将内存大致分为4个区域
- 代码区:存放函数体的二进制代码,由 *** 作系统进行管理
- 全局区:存放全局变量、静态变量以及常量
- 栈区:由编译器自动分配释放,存放函数的参数值,局部变量等
- 堆区: 由程序员分配和释放,若程序员不释放,程序结束时由 *** 作系统回收
在程序编译连接后,生成了exe可执行程序,在未执行该程序前分为两个区域
代码区:
- 存放CPU执行的机器指令
- 代码区是共享的,共享的目的是对于频繁被执行的程序,只需要在内存中有一份代码即可
- 代码区是只读的,只读的原因是防止程序意外地修改了它的指令
全局区:
- 全局变量和静态变量存放于此
- 全局区还包含了常量区,字符串常量和其它常量
- 该区域的数据在程序结束后由 *** 作系统释放
栈区:
注意事项:不要返回局部变量的地址,因为栈区开辟的数据由编译器自动释放
int* func()
{
int a = 10; //局部变量 存放在栈区,栈区的数据在函数执行完后自动释放
return &a; //返回局部变量的地址
}
int main()
{
//接受func函数的返回值
int *p = func();
cout << *p << endl; // 第一次可以打印正确的数字,因为编译器做了保留
cout << *p << endl; // 第二次这个数据就不再保留
system("pause");
return 0;
}
堆区:
- 在C++中主要利用new在堆区开辟内存,释放利用 *** 作符delete
- 利用new创建的数据,会返回该数据对应的类型的指针
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)