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)分配的。

相关推荐
blasit1 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
肆忆_2 天前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
不想写代码的星星3 天前
虚函数表:C++ 多态背后的那个男人
c++
端平入洛4 天前
delete又未完全delete
c++
端平入洛5 天前
auto有时不auto
c++
哇哈哈20216 天前
信号量和信号
linux·c++
多恩Stone6 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
蜡笔小马6 天前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost
超级大福宝6 天前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
weiabc6 天前
printf(“%lf“, ys) 和 cout << ys 输出的浮点数格式存在细微差异
数据结构·c++·算法