首先我们来简单看一下堆和栈:
1、堆和栈是两种数据结构,只能在一端对数据项进行插入和删除。
2、在单片机应用中,堆栈是个特殊的存储区,主要是暂时存放数据和地址。
3、堆,队列优先,先进先出。
4、栈,先进后出。
(视频教程推荐:java视频)
堆和栈的比较:
1、栈(stack)与堆(heap)都是java用来在内存中存放数据的地方。
2、java自动管理栈堆,程序员不需要理会(与C++不同)。
3、栈,存储速度比堆快,仅次于CPU中的寄存器。缺点是,大小和生命周期是确定的缺少灵活性。
4、栈数据在多线程或者多个栈之间是不可以共享的
5、栈内部的多个值相等的变量是可以指向同一个地址的。
6、堆的优势可以动态地分布内存的大小,生命周期也是动态的。
7、java垃圾收集器会自动的收走不在使用的堆数据。
8、堆的缺点是,要在运行时动态分配内存,存取速度较慢。
推荐教程:java入门程序