java的内存分为栈(stack)和堆(heap);
1、栈(stack)
(1)定义
每个应用运行时都有自己的一段内存空间,用于存放临时变量、参数传递、函数调用时的PC值以及对象的引用,这叫stack。
(2)优缺点
优点:存取速度比堆快,仅次于CPU中的寄存器。另外,
缺点:存在栈中的数据的大小与生存期必须是确定的,所以缺乏灵活性。
2、堆(heap)
(1)定义
堆是JVM的内存数据区。Heap的管理很复杂,每次分配不定长的内存空间专门用来保存对象的实例(实际上是保存对象实例的属性值,属性的类型和对象本身的类型标志等),并不保存对象的方法(方法是指令,保存在栈中)。
(2)优缺点
优点:堆是一个运行时的数据区,它的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时动态分配内存的,java的垃圾收集器会自动收走这些不再使用的数据。
缺点:由于在运行时动态分配内存,存取速度比较慢。
本文详细介绍了Java内存管理中的两个核心概念——栈和堆。栈用于存储临时变量、参数和对象引用,具有快速存取的优点但缺乏灵活性;堆则用于动态分配内存以保存对象实例,虽然存取较慢,但能实现灵活的内存管理并通过垃圾回收机制自动清理。
548

被折叠的 条评论
为什么被折叠?



