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;
}
相关推荐
郝学胜-神的一滴26 分钟前
跨平台动态库与头文件:从原理到命名的深度解析
linux·c++·程序人生·unix·cmake
代码中介商26 分钟前
C++ 仿函数(Functor)深度解析:从基础到应用
开发语言·c++
王老师青少年编程36 分钟前
csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:[NOIP 2018 普及组] 标题统计
c++·字符串·csp·高频考点·信奥赛·专项训练·标题统计
辰同学ovo41 分钟前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
ting945200042 分钟前
告别无效学习:Scholé 如何用 AI 重构职场学习,让学习直接嵌入工作流
人工智能·学习·重构
xian_wwq42 分钟前
【学习笔记】Harness到底是什么
笔记·学习·ai·harness
二哈赛车手44 分钟前
新人笔记---项目中简易版的RAG检索后评测指标(@Recall ,Mrr..)实现
java·开发语言·笔记·spring·ai
wuxinyan1231 小时前
大模型学习之路004:RAG 零基础入门教程(第一篇):基础理论与文档处理流水线
人工智能·学习·rag
冯诺依曼的锦鲤1 小时前
从零实现高并发内存池:TCMalloc 核心架构拆解
c++·学习·算法·架构
网络工程小王2 小时前
【LangChain Output Parser 输出解析器】输出篇
人工智能·学习·langchain