开发与运行Java程序需要经过的三个主要步骤是?

开发与运行Java程序需要经过的三个主要步骤是?,第1张

创建Java源程序

Java源程序一般用java作为扩展名,是一个文本文

件,用Java语言写成,可以用任何文本编辑器创建

与编辑;

编译源程序

Java编译器,“javac”,读取你的Java源程序并翻译

成Java虚拟机能够明白的指令集合,且以字节码的

形式保存在文件中。通常,字节码文件以class作为

扩展名;

运行class(字节码)文件

Java解释器读取字节码,取出指令并且翻译成计算

机能执行的代码,完成运行过程;

第一步(编译): 创建完源文件之后,程序会先被编译为.class文件。Java编译一个类时,如果这个类所依赖的类还没有被编译,编译器就会先编译这个被依赖的类,然后引用,否则直接引用,这个有点象make。

如果java编译器在指定目录下找不到该类所其依赖的类的.class文件或者.java源文件的话,编译器话报“cant find symbol”的错误。

第二步(运行):java类运行的过程大概可分为两个过程:1、类的加载 2、类的执行。需竖罩要说明的是:JVM主要在程序第一次主动使用类的时候,才会去加载该类。也就是说,JVM并不是在一开始就把一个程序就所有的类都加载到内存中,而是到不得不用的时候才把它加载进来,而且只加载一次。

特别说明:java类中所有public和protected的实例方法都采用动态绑定机制,所有私有方法、静态方法、构造器及初始化方法<clinit>都是采用静态绑定机制。而使用动态绑定机制的时候会用到方法表,静态绑定时并不会用到。

扩展资料:

Java整个编译以及运行的过程相当繁琐,本文通过一个简单的程序来简单的说明整个流程。

Java代码编译:是由Java源码编译器来完成

Java字节码的执行:是由JVM执行引擎来完成

Java程序从源文件创建到程序运行要经过两大步骤:

1、源文件由编译器编译成字节码(ByteCode)迹纤旁

2、字节码由java虚拟机解释运行。因为java程序既要编译同时也要经过姿橡JVM的解释运行,所以说Java被称为半解释语言( "semi-interpreted" language)。

1,如果java文件没有package,就默认给文件加上"无名"package

2,默认导入java.lang包,所以我们的java程序中可以使用Sting,Math,Integer等类,包括一些异常类

3,如果生成的类没有父类,则为这个类隐式加上父类:Object因此兆枣,包括Object中的许多方法可以使用

4,字段的初始化

二,我们所看的到的:

既然看的到,就先看程序运行结果:

public class JRun1 {

public JRun1() {

System.out.println(" 构造函数")

}

static

{

System.out.println("static{}")

}

{

System.out.println("{}")

}

public static void main(String[] args) {

System.out.println("main()")

}

}

运行结果:

static{}

main()

显然,程序运行时,先运行:

static

{

System.out.println("static{}")

}

再调用main()

如果我们在类中建立一个对象:

public class JRun1 {

public JRun1() {

System.out.println(" 构造函数")

}

static

{

System.out.println("static{}")

}

{

System.out.println("{}")

}

public static void main(String[] args) {

System.out.println("main()")

new JRun1()

}

}

运行结果:

static{}

main()

{}

构造函数

从而,我们得出:

建立一个非主类对象,顺序为:静态初始化块static{}-->初始化块{}-->构造函数constructor

那么,牵涉到继承,运行流程又如何?

看程序:

class JRun1Father{

JRun1Father(){

System.out.println("父类构造函数")

}

static{

System.out.println("父类静态初始化块")

}

{

System.out.println("父类初始化块")

}

}

public class JRun1 extends JRun1Father{

public JRun1() {

System.out.println("子类构造函数")

}

static

{

System.out.println("子类静态初始化块")

}

{

System.out.println("子类初始化块")

}

public static void main(String[] args) {

//System.out.println("主方法)")

new JRun1()

}

}

运行结果:

父类静态初始化块

子类静态初始化块

父类初始化块

父类构造函数

子类初始化块

子类构造函数

所以,牵涉到父类:父静态-->子静态-->父初始知绝化及构造-->子初始化及构造

注意:初始化块和构造是搭猜姿接连运行的,不会父类子类交替.


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12350962.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存