浅谈堆栈

由系统自动分配释放

向下分配,先进后出(FILO),压栈弹栈

速度快

小(1、2M)

编译时即确定内存大小

java由jvm管理堆栈,程序员无需插手

java中基础数据类型存储在栈中,immutable(不可变的),对象类型存储在堆中

String类型比较特殊

String str = "abc"; -- 存储在栈中 -- immutable(不可变的)

String str = new String("abc"); -- 存储在堆中

C++占用内存分为五个部分:栈区、堆区、静态区(static)、文字常量区、程序代码区

由程序分配释放

向上分配,先进先出(FIFO),类似链表

速度相对较慢

大(32位系统 - 4G)

由于动态分配不固定大小的内存,产生内存碎片

运行时解析器顺序寻找大于所需内存空间的链表空间

new操作符分配的是堆

转载于:https://my.oschina.net/maczhao/blog/525226

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值