java中
栈(stack)是由编译器自动分配和释放的一块内存区域,主要用于存放一些基本类型(如 int、float等)的变量、指令代码、常量以及对象句柄——(对象的引用地址)。
栈内存的操作方式,类似于数据结构中的栈(仅在表尾进行插入或删除操作的线性表)。
优势:存取速度比较快,仅次于寄存器
缺陷:存在栈中的大小与生存期必须是确定的,缺乏灵活性。
堆(heap)
是一个程序运行动态分配的内存区域。java中,构建对象时所需要的内存从堆中分配。对象由 new 指令 “显式”建立。放弃分配方式类似于数据结构的链表。堆内存的分配与回收都是“隐式”回收的。
优势:动态分配内存大小,可以按需分配。其生存期也不必实现告诉编译器,在使用完毕后,java的垃圾收集器会自动收走这些不再分配的内存块。
缺点:运行时分配内存,相比于栈内存,它的存取速度较慢。