C++面向对象编程(4)——浅谈C++内存模型

目录

[一. 说明](#一. 说明)

[二. GDB实验](#二. GDB实验)

[2.1 实验1:栈](#2.1 实验1:栈)

[2.2 实验2:堆](#2.2 实验2:堆)


一. 说明

不同的操作系统对程序内存的管理和划分会有所不同。如上图所示的C++内存区域划分主要是针对一般的情况,说明如下:

  1. Stack:栈。由编译器管理分配和回收,存放局部变量和函数参数。

2.Heap:堆。由程序员管理,需要⼿动 new malloc delete free 进⾏分配和回收,空间较⼤,但可能会出现内存泄漏和空闲碎⽚的情况。

  1. 内存映射段:高效的I/O映射方式,用于装载共享的动态内存库等。

  2. 全局/静态存储区

(1) BSS Segment:Block Started by Symbol,属于静态内存分配,用来存储未初始化的全局变量和静态变量。

(2) Data Segment:数据段。存储已经初始化了的全局变量和和静态变量。

  1. Text Segment:代码区 ,通常也被称为文本区或只读区。存放程序的二进制代码和常量,代码段是只读的,可以被多个进程共享;也有认为常量存储区 在内存中是独立的,C++标准并没有明确将常量存储区单独列为内存分区模型的一部分。

二. GDB实验

#include <iostream>
using namespace std;

int main(int argc, char** argv)
{
    int size = 100;
    char c = 'x';

    int* heap1 = (int*) malloc(sizeof(int));
    int* heap2 = (int*) malloc(sizeof(int));

    return 0;
}

2.1 实验1:栈

int size = 100;
char c = 'x';

从变量size地址(0x7fffffffdbdc)和变量c地址((0x7fffffffdbdb))可知:栈是从高地址向低地址伸展分配的。

2.2 实验2:堆

int* heap1 = (int*) malloc(sizeof(int));
int* heap2 = (int*) malloc(sizeof(int));

heap1/heap2是局部变量,放在栈上,可以看到他们地址0x7fffffff....是比较高的;而这两个变量所指向的地址是堆的地址,可以看到堆的地址(0x55555...)就相对栈的地址是比较低且是从低地址向高地址 伸展(b0->d0)分配的。

相关推荐
qmx_076 分钟前
MFC-基础架构
c++·mfc
万象.8 分钟前
STL_vector实现及干货以及vector迭代器失效问题
c++
想变成自大狂9 分钟前
C++中的异构容器
开发语言·c++
小米里的大麦13 分钟前
【C++】深入理解引用:从基础到进阶详解
c++·经验分享·笔记·引用·引用和指针
float_com1 小时前
【STL】stack,deque,queue 基础,应用与操作
c++·stl·极速入门
学习使我变快乐1 小时前
C++:用类实现链表,队列,栈
开发语言·c++·链表
lmy_t1 小时前
C++之第十二课
开发语言·c++
tyler-泰勒1 小时前
初始c++:入门基础(完结)
java·开发语言·c++
sinat_276522573 小时前
C++中move的使用
开发语言·c++
微尘84 小时前
C语言存储类型 auto,register,static,extern
服务器·c语言·开发语言·c++·后端