JVM之本地栈

Posted zmycoco2

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JVM之本地栈相关的知识,希望对你有一定的参考价值。

本地方法栈(Native Method Stacks)和Java虚拟机栈的功能很相似,Java虚拟机栈用于管理Java函数的调用,而本地方法栈用于管理本地方法的调用。本地方法并不是用Java实现的,而是使用C实现的。当某个线程调用一个本地方法时,它就进入了一个全新的并且不再受虚拟机限制的世界,本地方法可以通过本地方法接口来访问虚拟机运行时的数据区,但不止于此,它还可以做任何它想做的事情。比如,它甚至可以直接使用本地处理器中的寄存器,或者直接从本地内存的堆中分配任意数量的内存。总之,它和虚拟机拥有同样的权限(或者说能力)。


本地方法本质上是依赖于实现的,虚拟机实现的设计者可以自由地决定使用怎样的机制来让Java程序调用本地方法,任何本地方法接口都会使用某种本地方法栈。当线程调用Java方法时,虚拟机会创建一个新的栈帧并压入Java栈,然而当它调用的是本地方法时,虚拟机会保持Java栈不变,不再在线程的Java栈中压入新的帧,虚拟机只是简单地动态连接并直接调用指定的本地方法。我们可以把这个做法看做是虚拟机利用本地方法来动态扩展自己,就如同Java虚拟机的实现是按照其中运行的Java程序的顺序,调用属于虚拟机内部的另一个(动态连接的)方法。我们知道,当C语言编写的程序调用一个C函数时,其栈操作都是确定的,首先传递给该函数的参数以某个确定的顺序被压入栈,然后它的返回值也以确定的方式被传回给调用者。同样,这就是虚拟机实现本地方法栈的方式,很可能本地方法接口需要回调Java虚拟机中的Java方法(这也是由设计者决定的),在这种情形下,该线程会保存本地方法栈的状态并进入到另一个Java栈。就像其他运行时内存区一样,本地方法栈占用的内存区也不需要是固定大小的,它可以根据需要动态扩展或者收缩,某些JVM也允许用户或者程序员指定该内存区的初始大小以及最大、最小值。


注意,在SUN的HOT SPOT虚拟机中,不区分本地方法栈和虚拟机栈。因此,和虚拟机栈一样,它也会抛出StackOverFlowError和OutOfMemoryError。

欢迎关注麦克叔叔每晚10点说,让我们一起交流与学习。

以上是关于JVM之本地栈的主要内容,如果未能解决你的问题,请参考以下文章

JVM运行时数据区之虚拟机栈,本地方法栈和程序计数器

JVM运行时数据区之虚拟机栈,本地方法栈和程序计数器

JVM的本地方法栈

JVM之基本结构

JVM之内存管理

JVM内存模型