【针对性复习】2

静心、专注、思考...

目录


>C++中动态内存管理:

    C/C++程序内存分配,一个C/C++编译的程序占用内存分为以下几个部分:

  • 栈区(stack):由编译器自动分配与释放,存放为运行时函数分配的局部变量、函数参数、返回数据、返回地址等。其操作类似于数据结构中的栈。

  • 堆区(heap):一般由程序员自动分配,如果程序员没有释放,程序结束时可能有OS回收;其分配类似于链表。

  • 全局区3(静态区static):存放全局变量、静态数据、常量。程序结束后由系统释放。全局区分为已初始化全局区(data)和未初始化全局区(bss).

  • 常量区(文字常量区):存放常量字符串,程序结束后由系统释放。

  • 代码区:存放函数体(类成员函数和全局区)的二进制代码。

    三种内存分配方式

  1. 从静态存储区分配

  2. 从栈上创建

  3. 从堆上分配(动态内存分配)

程序在运行时使用malloc或者new申请人任意多少的内存,程序员自己负责在何时y用free或者delete释放内存。动态内存的生命周期由程序员决定,使用非常灵活,但如果在堆上分配了空间,要有责任回收它,否则运行的程序会出现内存泄漏,频繁的分配和释放不同大小的堆空间,将会产生内存碎片。

堆和栈的区别:

  • 管理方式不同:栈是由编译器自动申请和释放空间,堆是需要程序员手动申请和释放;

  • 空间大小不同:栈的空间是有限的,在32位平台下,VC6下默认为1M,堆最大可以到4G;

  • 能否产生碎片:栈和数据结构中的栈原理相同,在弹出一个元素之前,上一个已经弹出了,不会产生碎片,如果不停地调用malloc、free对造成内存碎片很多;

  • 生长方向不同:堆生长方向是向上的,也就是向着内存地址增加的方向,栈刚好相反,向着内存减小的方向生长。

  • 分配方式不同:堆都是动态分配的,没有静态分配的堆。栈有静态分配和动态分配。静态分配是编译器完成的,比如局部变量的分配。动态分配由 malloc 函数进行分配,但是栈的动态分配和堆是不同的,它的动态分配是由编译器进行释放,无需我们手工实现。

  • 分配效率不同:栈的效率比堆高很多。栈是机器系统提供的数据结构,计算机在底层提供栈的支持,分配专门的寄存器来存放栈的地址,压栈出栈都有相应的指令,因此比较快。堆是由库函数提供的,机制很复杂,库函数会按照一定的算法进行搜索内存,因此比较慢。

未完待续~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值