java栈的使用 如何准确理解Java中的堆与栈?
如何准确理解Java中的堆与栈?
谢谢
!Java运行时数据区有Java虚拟机栈和本地方法栈,用于执行方法;堆用于存储对象实例和数组。
Java虚拟机堆栈
执行每个Java方法时,将创建一个堆栈框架。堆栈帧用于存储局部变量列表、操作数堆栈、动态链表和方法出口等信息。每个Java方法从调用开始到执行完成的过程,对应于Java虚拟机栈中栈帧从栈入口到栈出口的过程。根据Java虚拟机规范,如果线程请求的深度大于虚拟机允许的深度,则抛出StackOverflowerError异常;如果虚拟机可以动态扩展,但扩展过程中内存不足,则抛出outofmemoryerror异常。Java虚拟机栈的生命周期遵循线程,是线程的私有生命周期。
Local method stack
Java虚拟机堆栈用于执行Java方法,而本地方法堆栈用于执行本地方法。它的功能类似于Java虚拟机堆栈,还抛出StackOverflowerError异常和outofmemoryerror异常。本地方法堆栈的生存期也是线程跟随和线程私有的。
Heap
堆是Java虚拟机中最大的内存空间。基本上,所有对象实例和数组都在这里分配内存空间,这是所有线程共享的。在Java虚拟机规范中,堆可以位于物理上不连续的内存空间中,只要它在逻辑上是连续的。当堆中没有足够的内存分配并且此时无法扩展时,将抛出outofmemoryerror异常。
关于数据结构的,为什么栈空top是-1,top=0是指向栈顶下一个元素,在共享栈中一号栈怎么为空?
函数中定义的一些基本类型变量和对象引用变量分配在函数的堆栈内存中。当在代码块中定义变量时,Java在堆栈中为变量分配内存空间。当超过变量的作用域时,Java会自动释放为变量分配的内存空间,该内存空间可以立即用于其他用途。堆内存用于存储由new创建的对象和数组。堆中分配的内存由Java虚拟机自动垃圾收集器管理。在堆中生成数组或对象后,还可以在堆栈中定义特殊变量。此变量的值等于堆内存中数组或对象的第一个地址。堆栈中的这个特殊变量成为数组或对象的引用变量,然后可以使用堆栈内存中的引用变量访问程序堆中的数组或对象。引用变量等效于数组或对象的别名或代码名。引用变量是公共变量。当它被定义时,内存被分配到堆栈中,引用变量被释放到程序范围之外。数组和对象本身在堆中分配。即使程序在使用new语句生成数组和对象的代码块之外运行,数组和对象本身占用的堆内存也不会被释放。当数组和对象没有引用指向它的变量时,它们就变成了垃圾并且不能再使用,但是它们仍然会在垃圾收集器释放的不确定时间内占用内存。这也是Java占用更多内存的主要原因。这些事情都是在虚拟机内完成的,我们不需要操作,你知道怎么回事。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。