C++内存学习笔记

C++内存学习笔记

1. 内存分区模型

1.1 程序运行前

不在全局中的数据

复制代码
1. 局部变量
2. const 修饰的局部变量

全局区

复制代码
1. 全局变量
2. 静态变量
3. 常量
	字符串常量
	const修饰的全局变量(全局常量)
4.该区域的的数据在程序结束后由操作系统释放
cpp 复制代码
#include <iostream>
using namespace std;

// 全局变量
int g_a = 10;
int g_b = 10;

// 全局常量
const int c_g_a = 10;

int main(int argc, char const *argv[])
{

    // 局部变量
    int a = 10;
    int b = 10;
    cout << "局部变量a的地址为:\t" << &a << endl;
    cout << "局部变量b的地址为:\t" << &b << endl;

    cout << "全局变量g_a的地址为:\t" << &g_a << endl;
    cout << "全局变量g_b的地址为:\t" << &g_b << endl;

    static int s_a = 10;
    static int s_b = 10;
    cout << "静态变量s_a的地址为:\t" << &s_a << endl;
    cout << "静态变量s_b的地址为:\t" << &s_b << endl;

    // 常量 
    const int c = 10;

    // 字符串常量
    const string p = "hello world";
    cout << "字符串常量的地址为:\t" << &("hello world") << endl;
    cout << "全局常量c_g_a的地址为:\t" << &c_g_a << endl << endl;

    const int c_l_a = 10;
    const int c_l_b = 10;
    cout << "局部常量c_l_a的地址为:\t" << &c_l_a << endl;
    cout << "局部常量c_l_b的地址为:\t" << &c_l_b << endl;
   

    return 0;
}

代码区

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

1.2 程序运行后

栈区

复制代码
1. 栈区的数据由编译器管理开辟和释放,在函数执行的期间自动分配,函数执行完毕,自动释放
2. 栈区的注意事项  -- 不要返回局部变量的地址
cpp 复制代码
#include <iostream>
using namespace std;

//栈区的注意事项  -- 不要返回局部变量的地址
//栈区的数据由编译器管理开辟和释放,在函数执行的期间自动分配,函数执行完毕,自动释放

int* func(){
    int a = 10; // 局部变量 存放在栈区,函数执行完毕后自动释放

    return &a; // 返回局部变量的地址
}

int main(int argc, char const *argv[])
{

    int * p = func();
    cout << p << endl; // 野指针
    return 0;
}

堆区

复制代码
由程序员分配释放,若程序员不释放,程序结束时由操作系统回收
利用new关键字,可以将数据开辟到堆区
cpp 复制代码
// 堆区开辟数据

int* func(){
    // 利用new关键字,可以将数据开辟到堆区
    // 指针本质也是局部变量 是放在栈区,指针指向的数据在堆区
    int* a = new int(10);

    return a; // 返回局部变量的地址
}

int main(int argc, char const *argv[])
{

    // 在堆区开辟数据
    int *p = func();
    cout << *p << endl;
    cout << p << endl;
    
    return 0;
}

1.3 new 操作符

复制代码
c++中用new操作符在堆区开辟数据
在堆区开辟的数据,由程序员手动开辟,手动释放
cpp 复制代码
// 在堆区利用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(int argc, char const *argv[])
{

    // 在堆区开辟数据
    test02();
    return 0;
}
相关推荐
tanyongxi6618 分钟前
C++ 特殊类设计与单例模式解析
java·开发语言·数据结构·c++·算法·单例模式
fqbqrr37 分钟前
2508C++,支持rdma通信的高性能rpc库
c++·rpc
rannn_1111 小时前
【MySQL学习|黑马笔记|Day7】触发器和锁(全局锁、表级锁、行级锁、)
笔记·后端·学习·mysql
liulilittle1 小时前
BFS寻路算法解析与实现
开发语言·c++·算法·宽度优先·寻路算法·寻路
喜欢吃燃面2 小时前
C++算法竞赛:位运算
开发语言·c++·学习·算法
传奇开心果编程2 小时前
【传奇开心果系列】Flet框架实现的家庭记账本示例自定义模板
python·学习·ui·前端框架·自动化
草莓熊Lotso2 小时前
《详解 C++ Date 类的设计与实现:从运算符重载到功能测试》
开发语言·c++·经验分享·笔记·其他
困鲲鲲2 小时前
CPP多线程2:多线程竞争与死锁问题
c++·多线程·死锁
_Kayo_8 小时前
node.js 学习笔记3 HTTP
笔记·学习
快乐的划水a11 小时前
组合模式及优化
c++·设计模式·组合模式