智能建站模版,建设工程公司名字大全三个字,开题报告 网站建设,备案域名怎么弄1. JVM是什么 JVM是Java Virtual Machine的缩写#xff0c;即咱们经常提到的Java虚拟机。虚拟机是一种抽象化的计算机#xff0c;有着自己完善的硬件架构#xff0c;如处理器、堆栈等#xff0c;具体有什么咱们不做了解。目前我们只需要知道想要运行Java文件#xff0c;必…1. JVM是什么 JVM是Java Virtual Machine的缩写即咱们经常提到的Java虚拟机。虚拟机是一种抽象化的计算机有着自己完善的硬件架构如处理器、堆栈等具体有什么咱们不做了解。目前我们只需要知道想要运行Java文件必须先通过一个叫javac的编译器将代码编译成class文件然后通过JVM把class文件解释成各个平台可以识别的机器码最终实现跨平台运行代码。 类装载器ClassLoader负责加载class文件。 执行引擎Execution Engine负责解释命令提交操作系统执行。 本地方法接口JNI本地接口的作用是融合不同的编程语言为Java所用。 本地方法栈NativeMethodStack登记native方法。 PC寄存器ProgramCountRegister存储指向下一条指令的地址。 方法区MethodArea线程共享静态变量常量类信息(构造方法/接口定义)运行时常量池存在方法区中。 Java栈JavaStack线程私有8种基本类型的变量对象的引用变量实例方法都栈内存中分配遵循先进后出原则。 堆Heap一个JVM实例只存在一个堆内存保存所有引用类型的真实信息。 2. JDK、JRE、JVM之间的关系
JDK全称为Java Development Kit汉语为java开发工具包即所有有关java的东西都包含在里面比如运行环境JRE、java的核心代码、JVM等等。
JRE全称为Java Runtime Environment汉语为java运行环境即想要运行java文件必须先有java的环境才行jre就是提供了这么一个环境。
JVM上面已经提到了JVM它是java最核心的部分。
简单用一张图来理解这三个的关系 二、JVM运行时数据区
1、运行时数据区包括哪几部分 根据《Java虚拟机规范》的规定运行时数据区通常包括这几个部分程序计数器(Program Counter Register)、Java栈(VM Stack)、本地方法栈(Native Method Stack)、方法区(Method Area)、堆(Heap)。 2、运行时数据区每部分存了那些数据 (1)、程序计数器 程序计数器Program Counter Register也有称作为PC寄存器。 虽然JVM中的程序计数器并不像汇编语言中的程序计数器一样是物理概念上的CPU寄存器但是JVM中的程序计数器的功能跟汇编语言中的程序计数器的功能在逻辑上是等同的也就是说是用来指示 执行哪条指令的。 由于在JVM中多线程是通过线程轮流切换来获得CPU执行时间的因此在任一具体时刻一个CPU的内核只会执行一条线程中的指令因此为了能够使得每个线程都在线程切换后能够恢复在切换之前的程序执行位置每个线程都需要有自己独立的程序计数器并且不能互相被干扰否则就会影响到程序的正常执行次序。因此可以这么说程序计数器是每个线程所私有的。 在JVM规范中规定如果线程执行的是非native方法则程序计数器中保存的是当前需要执行的指令的地址如果线程执行的是native方法则程序计数器中的值是undefined。 由于程序计数器中存储的数据所占空间的大小不会随程序的执行而发生改变因此对于程序计数器是不会发生内存溢出现象(OutOfMemory)的。 (2)、Java栈 Java栈也称作虚拟机栈Java Vitual Machine Stack也就是我们常常所说的栈跟C语言的数据段中的栈类似。事实上Java栈是Java方法执行的内存模型。为什么这么说呢下面就来解释一下其中的原因。 Java栈中存放的是一个个的栈帧每个栈帧对应一个被调用的方法在栈帧中包括局部变量表(Local Variables)、操作数栈(Operand Stack)、指向当前方法所属的类的运行时常量池运行时常量池的概念在方法区部分会谈到的引用(Reference to runtime constant pool)、方法返回地址(Return Address)和一些额外的附加信息。当线程执行一个方法时就会随之创建一个对应的栈帧并将建立的栈帧压栈。当方法执行完毕之后便会将栈帧出栈。因此可知线程当前执行的方法所对应的栈帧必定位于Java栈的顶部。讲到这里大家就应该会明白为什么 在 使用 递归方法的时候容易导致栈内存溢出的现象了以及为什么栈区的空间不用程序员去管理了当然在Java中程序员基本不用关系到内存分配和释放的事情因为Java有自己的垃圾回收机制这部分空间的分配和释放都是由系统自动实施的。对于所有的程序设计语言来说栈这部分空间对程序员来说是不透明的。下图表示了一个Java栈的模型 局部变量表顾名思义想必不用解释大家应该明白它的作用了吧。就是用来存储方法中的局部变量包括在方法中声明的非静态变量以及函数形参。对于基本数据类型的变量则直接存储它的值对于引用类型的变量则存的是指向对象的引用。局部变量表的大小在编译器就可以确定其大小了因此在程序执行期间局部变量表的大小是不会改变的。 操作数栈想必学过数据结构中的栈的朋友想必对表达式求值问题不会陌生栈最典型的一个应用就是用来对表达式求值。想想一个线程执行方法的过程中实际上就是不断执行语句的过程而归根到底就是进行计算的过程。因此可以这么说程序中的所有计算过程都是在借助于操作数栈来完成的。 指向运行时常量池的引用因为在方法执行的过程中有可能需要用到类中的常量所以必须要有一个引用指向运行时常量。 方法返回地址当一个方法执行完毕之后要返回之前调用它的地方因此在栈帧中必须保存一个方法返回地址。 由于每个线程正在执行的方法可能不同因此每个线程都会有一个自己的Java栈互不干扰。 3.本地方法栈 本地方法栈与Java栈的作用和原理非常相似。区别只不过是Java栈是为执行Java方法服务的而本地方法栈则是为执行本地方法Native Method服务的。在JVM规范中并没有对本地方发展的具体实现方法以及数据结构作强制规定虚拟机可以自由实现它。在HotSopt虚拟机中直接就把本地方法栈和Java栈合二为一。 4.堆 Java中的堆是用来存储对象本身的以及数组当然数组引用是存放在Java栈中的。只不过和C语言中的不同在Java中程序员基本不用去关心空间释放的问题Java的垃圾回收机制会自动进行处理。因此这部分空间也是Java垃圾收集器管理的主要区域。另外堆是被所有线程共享的在JVM中只有一个堆。 5.方法区 方法区在JVM中也是一个非常重要的区域它与堆一样是被线程共享的区域。在方法区中存储了每个类的信息包括类的名称、方法信息、字段信息、静态变量、常量以及编译器编译后的代码等。 在Class文件中除了类的字段、方法、接口等描述信息外还有一项信息是常量池用来存储编译期间生成的字面量和符号引用。 在方法区中有一个非常重要的部分就是运行时常量池它是每一个类或接口的常量池的运行时表示形式在类和接口被加载到JVM后对应的运行时常量池就被创建出来。当然并非Class文件常量池中的内容才能进入运行时常量池在运行期间也可将新的常量放入运行时常量池中比如String的intern方法。 在JVM规范中没有强制要求方法区必须实现垃圾回收。很多人习惯将方法区称为“永久代”是因为HotSpot虚拟机以永久代来实现方法区从而JVM的垃圾收集器可以像管理堆区一样管理这部分区域从而不需要专门为这部分设计垃圾回收机制。不过自从JDK7之后Hotspot虚拟机便将运行时常量池从永久代移除了。 int i 1 ; 局部变量存储在栈基本数据类型的局部变量数据值直接存储在栈中 String str hello; 局部变量存储在栈存储地址值,hello是字符串常量值存储在常量池 Integer num 200; 局部变量存储在栈存储地址值;200超出常量池中的范围[-128,127]Integer 是包装类对象对象存储在堆中 int[] arr {1,2,3,4,5};局部变量存储在栈存储地址值;数组存储在堆中 MyData() my new MyData();局部变量存储在栈存储地址值;对象存储在堆中,对象中的基本数据类型的成员/全局变量值存在堆中