栈为什么效率比堆高

栈为什么效率比堆高

总结如下:

1、有寄存器直接对栈进行访问(esp,ebp),而对堆访问,只能是间接寻址。

也就是说,可以直接从地址取数据放至目标地址;使用堆时,第一步将分配的地址放到寄存器,然后取出这个地址的值,然后放到目标地址。

2、栈中数据cpu命中率更高,满足局部性原理。

3、栈是编译时系统自动分配空间,而堆是动态分配(运行时分配空间),所以栈的速度快。

4、栈是先进后出的队列结构,比堆结构相对简单,分配速度大于堆。

“堆”和“栈”并不是数据结构上的Heap跟Stack,而是程序运行中的不同内存空间。

那么这就简单了,栈是程序启动的时候,系统分好了给你的,你自己用,系统不干预。

堆是用的时候才向系统申请的,用完了还回去,这个申请和交还的过程开销相对就比较大了。

栈与堆都是Java用来在Ram中存放数据的地方。

栈中主要存放一些基本类型的变量(,int, short, long, byte, float, double, boolean, char)。 存在栈中的数据可以共享。栈的优势是,存取速度比堆要快,仅次于寄存器,栈数据可以共享。但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。

堆是一个运行时数据区,类的(对象从中分配空间。由于要在运行时动态分配内存,存取速度较慢。 存在栈中的数据可以共享。

栈是编译时分配空间,而堆是动态分配(运行时分配空间),所以栈的速度快

cpu有专门的寄存器(esp,ebp)来操作栈,堆都是使用间接寻址的。栈快点

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 原文地址:C语言函数调用栈(一)C语言函数调用栈(二) 0 引言 程序的执行过程可看作连续的函数调用。当一个函数执...
    小猪啊呜阅读 4,972评论 1 19
  • 一、温故而知新 1. 内存不够怎么办 内存简单分配策略的问题地址空间不隔离内存使用效率低程序运行的地址不确定 关于...
    SeanCST阅读 8,133评论 0 27
  • 文/靖雯 小时候直到上了学,印象中都没有过什么女人的节日,甚至走入社会那会,也没怎么看到节日的问候如此满天飞;亦或...
    靖雯weny阅读 698评论 3 9
  • 秋天深了 王在写诗
    蒲未歇阅读 247评论 0 0

友情链接更多精彩内容