如何理解java中堆和栈的概念

如何理解java中堆和栈的概念

首先我们来简单看一下堆和栈:

1、堆和栈是两种数据结构,只能在一端对数据项进行插入和删除。

2、在单片机应用中,堆栈是个特殊的存储区,主要是暂时存放数据和地址。

3、堆,队列优先,先进先出。

4、栈,先进后出。

(视频教程推荐:java视频)

堆和栈的比较:

1、栈(stack)与堆(heap)都是java用来在内存中存放数据的地方。

2、java自动管理栈堆,程序员不需要理会(与C++不同)。

3、栈,存储速度比堆快,仅次于CPU中的寄存器。缺点是,大小和生命周期是确定的缺少灵活性。

4、栈数据在多线程或者多个栈之间是不可以共享的

5、栈内部的多个值相等的变量是可以指向同一个地址的。

6、堆的优势可以动态地分布内存的大小,生命周期也是动态的。

7、java垃圾收集器会自动的收走不在使用的堆数据。

8、堆的缺点是,要在运行时动态分配内存,存取速度较慢。

推荐教程:java入门程序

以上就是如何理解java中堆和栈的概念的详细内容,更多请关注其它相关文章!