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;
}
相关推荐
祝大家百事可乐5 分钟前
嵌入式——02 数据结构
c++·c#·硬件工程
Yu_Lijing7 分钟前
基于C++的《Head First设计模式》笔记——生成器模式
c++·笔记·设计模式
次旅行的库18 分钟前
【问渠哪得清如许-数据分析】学习笔记-下
数据库·笔记·sql·学习
计算机安禾27 分钟前
【C语言程序设计】第36篇:二进制文件的读写
c语言·开发语言·c++·算法·github·visual studio code·visual studio
Dfreedom.34 分钟前
机器学习经典算法全景解析与演进脉络(监督学习篇)
人工智能·学习·算法·机器学习·监督学习
sheji341637 分钟前
【开题答辩全过程】以 基于Android的奥运英语学习软件的设计与实现为例,包含答辩的问题和答案
学习
2301_8073671941 分钟前
C++代码风格检查工具
开发语言·c++·算法
Morwit42 分钟前
*【力扣hot100】 215. 数组中的第K个最大元素
数据结构·c++·算法·leetcode·职场和发展
吃杠碰小鸡43 分钟前
Python+Ai学习流程
人工智能·python·学习
博语小屋1 小时前
多路转接select、poll
开发语言·网络·c++·php