在Java中,栈是由编译器自动分配和释放的一块内存区域,主要用于存放一些基本类型的变量,指令代码,常量及对象句柄。(对象的引用地址)
栈内存的操作方式,类似于数据结构中的栈(仅在表尾进行插入或删除操作的线性表)。
栈的优势在于他的存取速度比较快,仅次于寄存器,栈中的数据还可以共享。其缺点为,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。
堆是一个程序运动动态分配的内存区域。在Java中,构建对象时所需要的内存从堆中分配。这些对象通过new指令“显式”建立,放弃分配方式类似于数据结构中的链表。堆内存在使用完毕后,是由垃圾回收(GC)器“隐式”回收的。
堆的优势在于,可以动态的分配内存大小,“按需分配”,其生存期也不用事先告诉编译器,在使用完毕后,Java的垃圾收集器会自动收走这些不再使用的内存块。其缺点为,由于要在运行时才能动态分配内存,相比于栈内存,他的存取速度较慢。
由于栈内存比较小,如果栈内存不慎耗尽,就会产生堆栈溢出,导致程序崩溃。