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

相关推荐
南境十里·墨染春水6 小时前
C++传记(面向对象)虚析构函数 纯虚函数 抽象类 final、override关键字
开发语言·c++·笔记·算法
2301_797172756 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
比昨天多敲两行7 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4507 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
问好眼8 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
海海不瞌睡(捏捏王子)8 小时前
C++ 知识点概要
开发语言·c++
minji...10 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
小菜鸡桃蛋狗12 小时前
C++——类和对象(下)
开发语言·c++
crescent_悦12 小时前
C++:Highest Price in Supply Chain
开发语言·c++
feng_you_ying_li12 小时前
底层实现map和set的第一步,AVL树的学习
c++