博客
关于我
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学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(72)——MySQL 开发者开发,设计规范再总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>