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

相关推荐
怀揣小梦想15 小时前
跟着Carl学算法--哈希表
数据结构·c++·笔记·算法·哈希算法·散列表
努力努力再努力wz15 小时前
【C++进阶系列】:万字详解unordered_set和unordered_map,带你手搓一个哈希表!(附模拟实现unordered_set和unordered_map的源码)
java·linux·开发语言·数据结构·数据库·c++·散列表
加油=^_^=15 小时前
【C++】哈希表
数据结构·c++·散列表
对纯音乐情有独钟的阿甘15 小时前
【C++庖丁解牛】哈希表/散列表的设计原理 | 哈希函数
c++·哈希算法·散列表
励志不掉头发的内向程序员15 小时前
【STL库】哈希表的原理 | 哈希表模拟实现
开发语言·c++·学习·散列表
玩镜的码农小师兄15 小时前
[从零开始面试算法] (04/100) LeetCode 136. 只出现一次的数字:哈希表与位运算的巅峰对决
c++·算法·leetcode·面试·位运算·hot100
tan77º16 小时前
【项目】基于多设计模式下的同步&异步日志系统 - 项目介绍与前置知识
linux·c++·设计模式
给大佬递杯卡布奇诺16 小时前
FFmpeg 基本API avcodec_open2函数内部调用流程分析
c++·ffmpeg·音视频
进击的圆儿16 小时前
高并发内存池项目开发记录 - 02
开发语言·c++·实战·项目·内存池
YXXY31316 小时前
二叉树进阶
c++