博客
关于我
C++的内存分类
阅读量:200 次
发布时间:2019-02-28

本文共 1536 字,大约阅读时间需要 5 分钟。

1.C++中的内存分为五大区域:

(1)      栈   存放局部变量,函数形参 调用函数式系统会自动分配一个栈

(2)      堆   存放由new存放的内存块,如果没有使用delete及时清理,会造成内存泄露

(3)      自由存储区    存放由malloc申请的内存块,

(4)      全局变量/静态变量区  存放全局变量静态变量

(5)      常量区  存放整数字符串等的常量

堆和栈的区别:

栈由系统自动分配,堆由程序员自己申请,系统在内存中寻找空闲的内存,将对应的内容写入空闲的内存。栈申请效率高,但大小有限制,堆申请效率较低。栈向低地址方向生长,堆向高地址方向生长。

代码:

# include 
using namespace std;# include
int global=1; //全局/静态变量区int main(){int a;char b[12];char *c=new char (); //栈区char *e=(char *)malloc(8*sizeof(char)); //分配的内存块在堆中,指针e在栈中int d=5; //常量区return 0;}

上面的代码产生的汇编代码是:

gdb) disas mainDump of assembler code for function main:   0x004016b0 <+0>:     push   %ebp   0x004016b1 <+1>:     mov    %esp,%ebp   0x004016b3 <+3>:     and    $0xfffffff0,%esp   0x004016b6 <+6>:     sub    $0x30,%esp   0x004016b9 <+9>:     call   0x401d00 <__main>   0x004016be <+14>:    movl   $0x1,(%esp)   0x004016c5 <+21>:    call   0x401760 <_Znwj>   0x004016ca <+26>:    movb   $0x0,(%eax)   0x004016cd <+29>:    mov    %eax,0x2c(%esp)   0x004016d1 <+33>:    mov    $0x8,%eax   0x004016d6 <+38>:    mov    %eax,(%esp)   0x004016d9 <+41>:    call   0x403728 
0x004016de <+46>: mov %eax,0x28(%esp) 0x004016e2 <+50>: movl $0x5,0x24(%esp) 0x004016ea <+58>: mov $0x0,%eax 0x004016ef <+63>: jmp 0x4016f9
0x004016f1 <+65>: mov %eax,(%esp) 0x004016f4 <+68>: call 0x401f70 <_Unwind_Resume> 0x004016f9 <+73>: leave 0x004016fa <+74>: retEnd of assembler dump.(gdb)

由汇编代码可知,指针c位于栈偏移0x2c的位置,指针e位于栈偏移0x28的位置,整数d位于栈偏移0x24的位置,变量a和b由于未初始化,没有分配内存。

转载地址:http://nmwp.baihongyu.com/

你可能感兴趣的文章
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>