艾巴生活网

您现在的位置是:主页>教育 >内容

教育

java源代码怎么运行(java源代码如何用)

2024-01-15 19:42:01教育帅气的蚂蚁
java源代码怎么用?1 写java源程序。java源文件是指存储java源代码的文件。(1)1)Java源文件名是源文件中公共类的名称;(2)一个java源文件可

java源代码怎么运行(java源代码如何用)

java源代码怎么用?

1.写java源程序。java源文件是指存储java源代码的文件。

(1)1)Java源文件名是源文件中公共类的名称;(2)一个java源文件可以包含多个类,但只允许有一个类是公共的。

二、编译java源代码

java源代码完成后,需要用编译器编译。安装jdk后,我们打开jdk目录,有两个。exe文件,即javac.exe(编译源代码,xxx.class文件)和java.exe(执行字节码,xxx.class文件)。

1、切换到MyTest.java文件夹;2、javac.exe编译MyTest.java。编译后发现e:\\Blogs目录中有很多以class为后缀的文件:A.class,B.class,MyTest.class提示:javac.exe编译java源代码时,java源代码中有几个类,会被编译成一个对应的字节码文件(。class file),其中字节码文件的文件名就是每个类的类名。应该注意,即使该类没有在源文件中定义,它也会被源文件引用。编译后,相应的字节码文件将被编程。比如A类引用了C类,但是C类没有在A类的源文件中定义,编译后C类也被编译成对应的字节码文件C.class

第三,执行java源文件,执行java源文件,用java.exe执行。

JVM如何执行字节码文件?

(1)加载字节码文件

当。java源代码被javac.exe编译器编译成. class字节码文件,接下来的工作就交给JVM了。

首先,JVM通过类加载器将类文件和相关的Java API加载到JVM中,以便进行后续处理。

这个阶段涉及到以下基本概念和知识。

1.1之间的关系。JDK、JRE和JVM

JDK(Java Development Kit),Java开发工具包,主要用于开发。在JDK7之前,JDK包括JRE。

JRE(Java Runtime Environment)是Java程序运行的核心环境,包括JVM和一些核心库。

JVM(Java虚拟机),VM是计算设备的规范。它是一台虚拟的计算机,是在一台实际的计算机上模拟各种计算机功能而实现的。它是JRE的核心模块。

2.JVM: JVM是计算设备的规范。它是一台虚拟的计算机,是在一台实际的计算机上模拟各种计算机功能而实现的。Java虚拟机的主要任务是加载类文件并执行其中的字节码。不同的Java虚拟机可能有不同的执行引擎实现。大致有以下几种引擎:一次性字节码解释引擎、即时编译引擎、自适应优化器、虚拟机实现模式,虚拟机实现模式根据具体厂商采用软件模式、硬件模式、软硬件结合模式。

3.什么是类加载器?

虚拟机的主要任务是加载类文件并执行字节码,类文件由虚拟机的类加载器完成。一个Java虚拟机中可能有多个类装入器。任何java应用程序都可能使用两种类装入器,即引导类装入器和用户自定义类装入器。启动类加载器是Java虚拟机的唯一部分,它可以分为原始类加载器、系统类加载器或默认类加载器。它的主要功能是从操作系统的磁盘中加载相应的类,比如Java API类。自定义加载类,即以自定义的方式加载类。

(2)将字节码文件存储在JVM存储区

JAVA虚拟机运行一个程序,需要内存来存储很多东西。如字节码、程序创建的对象、传递给方法的参数、返回值、局部变量和操作的中间结果等。它们被组织到“运行时数据区”中。根据不同的供应商,Java虚拟机中的运行时数据区是不同的。一些运行时数据区域由线程共享,而另一些则只能由特定的线程共享。运行时数据区大致可以分为几个区域:方法区、堆区、堆栈区、PC寄存器区和本地方法堆栈区。这个阶段涉及到以下基本概念和知识。

1、方法区域:方法区域用于存储与解析加载的类文件相关的信息。当类文件被虚拟加载时,它将从类文件中包含的二进制数据中解析类型信息,然后将相关信息存储在方法区域中。

2.堆:堆用于存储相关的引用类型,比如新对象。当程序运行时,虚拟机将程序创建的所有对象放入堆中。

3.PC寄存器:PC寄存器主要用于存储线程。当一个新线程被创建时,它将获得自己的PC寄存器(程序计数器)和一个java堆栈。Java虚拟机没有寄存器,其指令集使用Java栈存储中间数据。

4.堆栈区:堆栈区主要用来存储值类型,比如基本数据类型。请注意,String是引用类型,存在于堆中。Java堆栈由许多堆栈框架组成。一个堆栈帧包含一个Java方法调用的状态。当线程调用一个方法时,虚拟机会将新的堆栈帧推入线程的Java堆栈。当方法返回时,堆栈框架从Java堆栈中弹出。

(3)执行引擎与运行时数据区交互,运行时数据区为执行引擎提供执行环境和相关数据。通过与运行时数据区的交互,执行引擎可以获得执行过程中所需的相关信息,并存储执行的中间结果。

(4)执行引擎和本地方法之间的接口。当要执行本地方法时,执行引擎将调用本地方法接口来获取相关的OS本地方法。注意,本地方法与操作系统是强耦合的。

(5)JVM在特定操作系统上执行,JVM通过调用本地接口获取本地方法,从而实现在特定平台上的执行。比如在Linux系统、Window系统、Unix系统上执行。