博客
关于我
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/

你可能感兴趣的文章
MySQL学习-SQL语句的分类与MySQL简单查询
查看>>
MySQL学习-子查询及limit分页
查看>>
MySQL学习-排序与分组函数
查看>>
MySQL学习-连接查询
查看>>
Mysql学习总结(10)——MySql触发器使用讲解
查看>>
Mysql学习总结(11)——MySql存储过程与函数
查看>>
Mysql学习总结(12)——21分钟Mysql入门教程
查看>>
Mysql学习总结(13)——使用JDBC处理MySQL大数据
查看>>
Mysql学习总结(14)——Mysql主从复制配置
查看>>
Mysql学习总结(15)——Mysql错误码大全
查看>>
Mysql学习总结(16)——Mysql之数据库设计规范
查看>>
Mysql学习总结(17)——MySQL数据库表设计优化
查看>>
Mysql学习总结(18)——Mysql主从架构的复制原理及配置详解
查看>>
Mysql学习总结(19)——Mysql无法创建外键的原因
查看>>
Mysql学习总结(19)——Mysql无法创建外键的原因
查看>>
Mysql学习总结(1)——常用sql语句汇总
查看>>
Mysql学习总结(20)——MySQL数据库优化的最佳实践
查看>>
Mysql学习总结(21)——MySQL数据库常见面试题
查看>>
Mysql学习总结(22)——Mysql数据库中制作千万级测试表
查看>>
Mysql学习总结(23)——MySQL统计函数和分组查询
查看>>