java里面Heap和Stack分别存储数据的不同
Heap(堆) | Stack(栈) | |
JVM中的功能 | 内存数据区 | 内存指令区 |
存储数据 | 对象实例(1) |
基本数据类型,
指令代码,常量,
对象的引用地址
(2)
|
对象实例在Heap中分配好以后,需要在Stack中保存一个4字节的heap内存地址,用了定位该对象实例在heap中的位置,便于找到该对象实例。
2.基本数据类型包括:byte、int、char、long、float、double、boolean和short。
函数方法属于指令。
java堆和栈的区别:
java的堆是一个运行时数据区,类的对象从中分配空间。这些对象通过new、newarray、anewarray和multianewarray等指令建立,它们不需要程序代码来显式的释放。堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是运行时动态分配内存的,java的垃圾收集器会自动收走这些不再使用的数据。但缺点是,由于要在运动时分配内存,存取速度较慢。
栈的优势是,存取速度比堆要快,仅次于寄存器,栈数据可以共享。但是缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。栈中主要存放一些基本类型的变量(byte、int、char、long、float、double、boolean和short)和对象句柄。
由此可见,垃圾回收GC是针对堆的,而栈因为本身是FILO-first in, last out.先进后出,能够自动释放。这样就能明白new创建的,都是放在堆。