在我们通过JVM编译Java后缀名的文件时,JVM首先寻找入口(main方法)
public static void main(String[] args)
1、由于在入口时,未调用任何对象,该方法只能设置为static静态
2、JVM为Java的最底层,所以即使有返回结果,结果也无处可去,因此该方法必然是void无返回值
3、由于main方法是入口,被JVM自动调用,只有将该方法设置为public公有级别才能对JVM可见
综上,入口main方法只能写为
public static void main(String[] args)
在我们没有写main方法时,系统会自动会为我们添加一个无参mian主方法,该方法的添加位置为public类中首行(之前也提到过,只有添加在public级别中才对JVM可见,可以自动调用)
注意:如果在java文件中未包含任一公共类(public class),此文件依然可以通过编译,但是主动运行由于找不到public class,就无法自动添加main方法,JVM找不到程序入口,运行会报错,即编译通过运行报错,缺少public class的文件需要等待被其它java文件调用,无法作为入口。
package j2se; class X{ Y y=new Y(); public X(){ System.out.print("X"); } } class Y{ public Y(){ System.out.print("Y"); } } //public class Z extends X{ // Y y=new Y(); // public Z(){ // System.out.print("Z"); // } // public static void main(String[] args) { // new Z(); // } //}
报错:
错误: 找不到或无法加载主类 j2se.Z
原因: java.lang.ClassNotFoundException: j2se.Z
当我们加上public类(public class)后,编译运行通过,根据返回结果可以清楚看到程序的执行顺序,代码如下:
package j2se; class X{ Y y=new Y(); public X(){ System.out.print("X"); } } class Y{ public Y(){ System.out.print("Y"); } } public class Z extends X{ Y y=new Y(); public Z(){ System.out.print("Z"); } public static void main(String[] args) { new Z(); } }
运行结果:YXYZ
根据这个运行结果,我们可以看出,程序运行后JVM编译顺序为,JVM直奔public class中main()方法作为入口,并开始编译执行
public static void main(String[] args)
以上所述是小编给大家介绍的Java文件执行顺序、main程序入口的详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
问题内容: 我尝试从一本书(Paul Hyde,Java Thread Programming)中运行示例。它说线程的顺序将互换。但是我总是得到:之后打印10个“主线程”,然后打印10个“新线程”。更有趣的是:如果我将使用tt.run而不是tt.start,那么结果将相反。也许这本书太老了,示例基于JDK 1.2的原因???代码如下: 问题答案: JVM决定何时将控制权从主线程转移到第二个线程。由
关于此代码段,我有一个问题要问您: 上面的脚本应该这样做: 设置位置哈希为 在任何进一步的变化- 这就是问题所在:为什么在第一次执行时调用?这个脚本不应该只更改哈希而不更改任何警报吗? 我如何修复它,使其按描述工作?
本文向大家介绍浅谈Vue的加载顺序探讨,包括了浅谈Vue的加载顺序探讨的使用技巧和注意事项,需要的朋友参考一下 在Vuejs 1.0版本中,如果父子组件进行配合,它们的生命周期执行具有如下特点: 1. created总是先父后子 生命周期函数created总是按照从父到子的顺序依次执行,但是兄弟之间没有严格按照这样的顺序执行,估计是采用了异步函数,不仅如此,子组件在父组件中的插入顺序也是随机的,并
问题内容: 我如何从Java程序运行本地jar文件? jar文件不在Java调用程序的类路径中。 问题答案: 我建议你使用并启动一个新的JVM。 以下是一些入门知识:
问题内容: 到目前为止,我一直在使用方法在Java中执行代码。什么时候/为什么要使用或代替? 问题答案: 这是一个特殊的问题,因为这不应该是选择问题。 启动JVM时,你指定要运行的类,并且该类就是程序启动所在的类。 通过,我假设你的意思是JApplet方法。在浏览器中启动小程序时,指定的小程序的方法将作为第一业务顺序执行。 通过,我假设你的意思是Runnable的方法。这是启动新线程时调用的方法。
使用统一的控制脚本来初始化其他脚本 一般我都会有一个 Game.ts 的脚本作为总的控制脚本,假如我还有 Player.ts, Enemy.ts, Menu.ts 三个组件,那么他们的初始化过程是这样的: // Game.ts import { _decorator, Component, Node } from "cc"; const { ccclass, property } = _decor