[c++]程序的内存划分理解

  • 全局和静态数据区:用于存放全局变量和静态变量(全局变量和局部变量)

  • 常量数据区:用于存放常量数据

  • 代码区:用于存储代码

  • 栈:用于局部变量和函数参数

  • 堆:程序员申请(程序员控制的部分,new/delete


#include <stdio.h>
#include <stdlib.h>

int gGlobal=100; // global

int main(void){
char *pLocalString1="LocalString1";
const char *pLocalString2="LocalString2";
static int nLocalStatic=100;

int nLocal=10;
const int nLocalConst=20;

int *pNew = new int[5];
char *pMalloc = (char*)malloc(1);

printf("global var 0x%x\n",&gGlobal);
printf("static var 0x%x\n",&nLocalStatic);
printf("\n");
printf("local var1 0x%x\n",&pLocalString1);
printf("local var2(const) 0x%x\n",&pLocalString2);

printf("\n");

printf("pNew 0x%x\n",pNew);
printf("pMalloc 0x%x\n",pMalloc);

pLocalString1[1]=‘a‘;//error 字符常量,数据定义好后,不能在修改.该地址,在编译前已经确定好
printf("\n");

printf("local point(pNew) 0x%x\n",&pNew);
printf("local point(pMalloc) 0x%x\n",&pMalloc);
printf("local point(pLocalString1) 0x%x\n",&pLocalString1);
printf("local point(pLocalString2) 0x%x\n",&pLocalString2);
printf("local point(nLocalConst) 0x%x\n",&nLocalConst);
printf("local point(nLocal) 0x%x\n",&nLocal);

}

[c++]程序的内存划分理解,布布扣,bubuko.com

时间: 2025-01-04 06:21:24

[c++]程序的内存划分理解的相关文章

[转载] - 程序员对内存的理解

程序员对内存的理解 原文链接 在C和C++语言开发中,指针.内存一直是学习的重点.因为C语言作为一种偏底层的中低级语言,提供了大量的内存直接操作的方法,这一方面使程序的灵活度最大化,同时也为bug埋下很多隐患. 因此,无论如何,我们都要对内存有一个清晰的理解. 一.对内的分配 32位操作系统支持4GB内存的连续访问,但通常把内存分为两个2GB的空间,每个进程在运行时最大可以使用2GB的私有内存(0x00000000—0x7FFFFFFF).即理论上支持如下的大数组: char szBuffer[

FW:程序在内存的划分(转)

一.预备知识—程序的内存分配 一个由c/C++编译的程序占用的内存分为以下几个部分 1.栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等.其操作方式类似于数据结构中的栈. 2.堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收.注意它与数据结构中的堆是两回事,分配方式倒是类似于链表,呵呵. 3.全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域,未初始化的全局变量和未初始

jvm运行时内存划分

(根据<深入理解java虚拟机>这本书总结) 本文主要解释jvm内存模型,以及各个部分的作用.都是自己总结的给自己看的通俗语言,未用专业术语的见谅. 一.为什么要了解jvm内存模型? 在了解一个类的编译-加载-内存分配-初始化所有过程前,要先了解jvm的内存模型.这样对整个java体系可能会更加便于理解.当然,如果不理解这些,也是没关系的,照样可以进行java开发. 二.jvm内存模型 1.根据自己的理解举个最简单的例子,一个main方法启动,进程运行,在这个过程中,会调用方法.开启多个线程.

JVM内存划分总结

概述 在说jvm内存划分之前,先来说下java程序具体的执行流程: Java源文件经过java编译器编译后变成class字节码文件, Jvm的classloader加载class文件完成后,交由execution engine执行. 执行引擎执行过程中用到的所有数据和信息,都存储在runtime data area中. Runtime data  area 就是我们常说的JVM内存. Runtime data area Runtime data area 都包括什么呢? <Java虚拟机规范>

程序的内存布局——函数调用栈的那点事

[注]此文是<程序员的自我修养>的读书总结,其中掺杂着一些个人的理解,若有不对,欢迎拍砖. 程序的内存布局 现代的应用程序都运行在一个虚拟内存空间里,在32位的系统里,这个内存空间拥有4GB的寻址能力.现代的应用程序可以直接使用32位的地址进行寻址,整个内存是一个统一的地址空间,用户可以使用一个32位的指针访问任意内存位置. 在进程的不同地址区间上有着不同的地位,Windows在默认情况下会将高地址的2GB空间分配给内核,而Linux默认将高地址的1GB空间分配给内核,具体的内存布局如下图:

.Net程序的内存管理和垃圾回收机制

.NET 内存管理和垃圾回收 C/C++ 程序需要开发者手动分配和释放内存,.Net程序则使用垃圾回收技术自动收集不再使用的内存.垃圾回收器(GC)使用引用 跟踪占用内存的对象,如果对象被设置为null或已不在使用范围,GC就会标志该对象为可回收,这样GC就可以回收被这些对象占用的内存. 垃圾回收器(GC)使用Win32? VirtualAlloc() 接口为自己的堆分配内存,.Net托管堆是一个巨大连续的虚拟内存.GC先预留虚拟内存,当托管堆增长时则提交内存.GC跟踪托管堆末尾可用的地址并把下

Android Dalvikvm 内存管理理解

网上很多文件介绍了 jvm 内存管理的理论,但在 Dalvikvm 中,究竟是如何实现的. 这几天猛看了 Dalvikvm 的源代码,说一下我的理解: 在大层面上讲跟理论一样,jvm 把内存分成了一些区, 关于各区的说明参见. http://blog.csdn.net/lengyuhong/article/details/5953544 对于hello world 这样简单程序,发现dalvikvm也就用了一个heap, 就是Eden区了. dalvikvm 使用 mmap 创建共享内存(堆是多

server后台程序的内存使用问题

眼下我开发的一个server后台程序存在这么一个问题,因为我的程序要不断的收发消息,并做统计.统计用的是stl的多重map.在统计中会不断的往map里赛数据. 可是每次统计后我都会调用clear()去释放内存,可是似乎并不奏效,仍然会有泄漏的现象.查资料,map的clear是将map内容清空,可是内存并不归还给系统,而是缓冲在内存池里以方便下次调用,有人提出,能够新建一个map,将两个map做swap操作,互换内容.然后delete这个新map.达到释放的效果.可是不奏效. 我也想到多重map,

如何优化cocos2d程序的内存使用和程序大小

在我完成第一个游戏项目的时候,我深切地意识到"使用cocos2d来制作游戏的开发者们,他们大多会被cocos2d的内存问题所困扰".而我刚开始接触cocos2d的时候,社区里面的人们讨论了一个非常有意义的话题:"请简单地讲述你认为新手cocos2d程序员在他开始编码之前,最应该先知道,或者应该关注和注意的事项."这个问题的答案很多,有人讲是"如何加载和保存游戏数据",有人讲的是"如何实现有限状态机"等等.而最吸引我的则是,有一