C++内存分区模型(代码区、全局区、栈区、堆区)

简介: C++内存分区模型(代码区、全局区、栈区、堆区)

一、代码区

代码区: 存放函数体的二进制代码,由操作系统进行管理的;(程序运行前)

存放CPU执行的机器指令
代码区是共享的,共享的目的是对于频繁被执行的程序,只需要在内存中有一份代码即可
代码区是只读的,使其只读的原因是防止程序意外地修改了它的指令

二、全局区

全局区:存放全局变量和静态变量以及常量;(程序运行前)

全局变量和静态变量存放在此
全局区还包含了常量区,字符串常量和其他常量也存放在此
该区域的数据在程序结束后由操作系统释放
#include <iostream>
 
using namespace std;
//全局变量
int g_a = 10;
int g_b = 10;
//const修饰的全局变量,全局常量
const int c_g_a = 10;
 
int main() {
//局部变量
    int a = 10;
    int b = 10;
    cout << "局部变量a的地址:" << &a << endl;
    cout << "局部变量b的地址:" << &b << endl;
    cout << "全局变量g_a的地址:" << &g_a << endl;
    cout << "全局变量g_b的地址:" << &g_b << endl;
//    静态变量
    static int s_a = 10;
    static int s_b = 10;
    cout << "静态变量s_a的地址:" << &s_a << endl;
    cout << "静态变量s_b的地址:" << &s_b << endl;
//    常量
//字符串
    cout << "字符串的地址" << &"hello" << endl;
//    全局常量
    cout << "全局常量c_g_a的地址:" << &c_g_a << endl;
//    局部常量
    const int c_a = 10;
    cout << "局部常量c_a的地址:" << &c_a << endl;
    return 0;
}
 
 

常量区:0x63,局部区:0x40.

局部变量a的地址:0x63fe1c
局部变量b的地址:0x63fe18
全局变量g_a的地址:0x404010
全局变量g_b的地址:0x404014
静态变量s_a的地址:0x404018
静态变量s_b的地址:0x40401c
字符串的地址0x405085
全局常量c_g_a的地址:0x405000
局部常量c_a的地址:0x63fe14
C++中在程序运行前分为全局区和代码区代码区
特点是共享和只读
全局区中存放全局变量、静态变量、常量
常量区中存放const修饰的全局常量和字符串常量

三、栈区

栈区:由编译器自动分配释放,存放函数的参数值,局部变量等。

由编译器自动分配释放,存放函数的参数值,
局部变量等注意事项: 不要返回局部变量的地址,栈区开辟的数据由编译器自动释放。


#include <iostream>
 
using namespace std;
 
int* func() {
    int a = 10; //局部变量存放在栈区,栈区数据在函数执行完成后,自动释放
    return &a; //返回局部变量地址
}
 
int main() {
    //接收函数返回的地址
    int* p = func();
    //    解指针打印
    cout << *p << endl;
    //    解指针打印
    cout << *p << endl;
    return 0;
}
 
 

x86运行会有问题

四、堆区

堆区:由程序员分配和释放,若程序员不释放,程序结束时由操作系统回收。

由程序员分配释放,若程序员不释放,程序结束时由操作系统回收;
在C++中主要利用new在堆区开辟内存;
#include <iostream>
 
using namespace std;
 
int* func() {
    // 利用new关键字 可以讲数据开辟到堆区;
    //指针 本质也是局部变量,放在栈上,指针保存的数据是放在堆区
    int* p = new int(10);
    return p;
}
 
int main() {
    //接收函数返回的地址
    int* p = func();
    //    解指针打印
    cout << *p << endl;
    //    解指针打印
    cout << *p << endl;
    return 0;
}
 
 

释放堆区空间

#include <iostream>
 
using namespace std;
 
//1、new的基本语法
int *func() {
//    在堆区创建整形数据
// new返回是该数据类型的指针
    int *p = new int(10);
    return p;
}
 
void test01() {
    int *p = func();
    cout << *p << endl;
    cout << *p << endl;
//    释放堆区数据
    delete p;
    cout << *p << endl; //引发了异常: 读取访问权限冲突。
 
}
 
//2、在堆区利用new开辟数组
void test02() {
    int *arr = new int[10];
    for (int i = 0; i < 10; ++i) {
        arr[i] = i + 100;
    }
    for (int i = 0; i < 10; ++i) {
        cout << arr[i] << endl;
    }
//    释放数组
    delete[] arr;
}
 
int main() {
    test01();
    test02();
    return 0;
}
 
 


相关文章
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
576 77
|
存储 C++ 索引
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
【数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】初始化队列、销毁队列、判断队列是否为空、进队列、出队列等。本关任务:编写一个程序实现环形队列的基本运算。(6)出队列序列:yzopq2*(5)依次进队列元素:opq2*(6)出队列序列:bcdef。(2)依次进队列元素:abc。(5)依次进队列元素:def。(2)依次进队列元素:xyz。开始你的任务吧,祝你成功!(4)出队一个元素a。(4)出队一个元素x。
475 13
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
|
11月前
|
存储 IDE Java
java设置栈内存大小
在Java应用中合理设置栈内存大小是确保程序稳定性和性能的重要措施。通过JVM参数 `-Xss`,可以灵活调整栈内存大小,以适应不同的应用场景。本文介绍了设置栈内存大小的方法、应用场景和注意事项,希望能帮助开发者更好地管理Java应用的内存资源。
627 4
|
存储 C语言 C++
【C++数据结构——栈与队列】链栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现链栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储整数,最大
266 9
|
C++
【C++数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】
【数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】(1)遇到左括号:进栈Push()(2)遇到右括号:若栈顶元素为左括号,则出栈Pop();否则返回false。(3)当遍历表达式结束,且栈为空时,则返回true,否则返回false。本关任务:编写一个程序利用栈判断左、右圆括号是否配对。为了完成本关任务,你需要掌握:栈对括号的处理。(1)遇到左括号:进栈Push()开始你的任务吧,祝你成功!测试输入:(()))
288 7
|
机器学习/深度学习 人工智能 自然语言处理
C++构建 GAN 模型:生成器与判别器平衡训练的关键秘籍
生成对抗网络(GAN)是AI领域的明星,尤其在C++中构建时,平衡生成器与判别器的训练尤为关键。本文探讨了GAN的基本架构、训练原理及平衡训练的重要性,提出了包括合理初始化、精心设计损失函数、动态调整学习率、引入正则化技术和监测训练过程在内的五大策略,旨在确保GAN模型在C++环境下的高效、稳定训练,以生成高质量的结果,推动AI技术的发展。
386 10
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
905 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
存储 算法 Java
Java 内存管理与优化:掌控堆与栈,雕琢高效代码
Java内存管理与优化是提升程序性能的关键。掌握堆与栈的运作机制,学习如何有效管理内存资源,雕琢出更加高效的代码,是每个Java开发者必备的技能。
324 5
|
存储
栈内存
栈内存归属于单个线程,也就是每创建一个线程都会分配一块栈内存,而栈中存储的东西只有本线程可见,属于线程私有。 栈的生命周期与线程一致,一旦线程结束,栈内存也就被回收。 栈中存放的内容主要包括:8大基本类型 + 对象的引用 + 实例的方法
160 1
|
6月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
2107 0