使用RuntimegetRuntime()exec()方法可以在java程序里运行外部程序。 1 exec(String command) 2 exec(String command, String envp[], File dir) 3 exec(String cmd, String envp[]) 4 exec(String cmdarray[]) 5 exec(String cmdarray[], String envp[]) 6 exec(String cmdarray[], String envp[], File dir) 一般的应用程序可以直接使用第一版本,当有环境变量传递的时候使用后面的版本。其中2和6版本可以传递一个目录,标识当前目录,因为有些程序是使用相对目录的,所以就要使用这个版本。 实例: Process process = RuntimegetRuntime()exec("\\pexe"); processwaitfor(); 在上面的程序中,第一行的“\\pexe”是要执行的程序名,RuntimegetRuntime()返回当前应用程序的Runtime对象,该对象的exec()方法指示Java虚拟机创建一个子进程执行指定的可执行程序,并返回与该子进程对应的Process对象实例。通过Process可以控制该子进程的执行或获取该子进程的信息。第二条语句的目的等待子进程完成再往下执行。
Java程序从源文件创建到程序运行要经过两大步骤:1、源文件由编译器编译成字节码(ByteCode)
2、字节码由java虚拟机解释运行。因为java程序既要编译同时也要经过JVM的解释运行,所以说Java被称为半解释语言( "semi-interpreted" language)。
下面通过以下这个java程序,来说明java程序从编译到最后运行的整个流程。代码如下:
//MainAppjava
public class MainApp {
public static void main(String[] args) {
Animal animal = new Animal("Puppy");
animalprintName();
}
}
//Animaljava
public class Animal {
public String name;
public Animal(String name) {
thisname = name;
}
public void printName() {
Systemoutprintln("Animal ["+name+"]");
}
}
第一步(编译): 创建完源文件之后,程序会先被编译为class文件。Java编译一个类时,如果这个类所依赖的类还没有被编译,编译器就会先编译这个被依赖的类,然后引用,否则直接引用,这个有点象make。如果java编译器在指定目录下找不到该类所其依赖的类的class文件或者java源文件的话,编译器话报“cant find symbol”的错误。
编译后的字节码文件格式主要分为两部分:常量池和方法字节码。常量池记录的是代码出现过的所有token(类名,成员变量名等等)以及符号引用(方法引用,成员变量引用等等);方法字节码放的是类中各个方法的字节码。下面是MainAppclass通过反汇编的结果,我们可以清楚看到class文件的结构:
第二步(运行):java类运行的过程大概可分为两个过程:1、类的加载 2、类的执行。需要说明的是:JVM主要在程序第一次主动使用类的时候,才会去加载该类。也就是说,JVM并不是在一开始就把一个程序就所有的类都加载到内存中,而是到不得不用的时候才把它加载进来,而且只加载一次。
下面是程序运行的详细步骤:
在编译好java程序得到MainAppclass文件后,在命令行上敲java AppMain。系统就会启动一个jvm进程,jvm进程从classpath路径中找到一个名为AppMainclass的二进制文件,将MainApp的类信息加载到运行时数据区的方法区内,这个过程叫做MainApp类的加载。
然后JVM找到AppMain的主函数入口,开始执行main函数。
main函数的第一条命令是Animal animal = new Animal("Puppy");就是让JVM创建一个Animal对象,但是这时候方法区中没有Animal类的信息,所以JVM马上加载Animal类,把Animal类的类型信息放到方法区中。
加载完Animal类之后,Java虚拟机做的第一件事情就是在堆区中为一个新的Animal实例分配内存, 然后调用构造函数初始化Animal实例,这个Animal实例持有着指向方法区的Animal类的类型信息(其中包含有方法表,java动态绑定的底层实现)的引用。
当使用animalprintName()的时候,JVM根据animal引用找到Animal对象,然后根据Animal对象持有的引用定位到方法区中Animal类的类型信息的方法表,获得printName()函数的字节码的地址。
开始运行printName()函数。
特别说明:java类中所有public和protected的实例方法都采用动态绑定机制,所有私有方法、静态方法、构造器及初始化方法<clinit>都是采用静态绑定机制。而使用动态绑定机制的时候会用到方法表,静态绑定时并不会用到。
第一步:下载并安装JDK 60,安装路劲为: C:\java\jdk16
第二步:对“我的电脑”按右键,选“属性”,在“系统属性”窗口中选“高级”标签,再按“环境变量”按钮,d出一个“环境变量”的窗口,在系统变量中新建一个变量,变量名为“JAVA_HOME“,变量值为"C:\java\jdk16";如果存在"PATH"变量名,按编辑,在变量值最前面输入"C:\java\jdk16\bin;"(注意以分号结尾,没有引号如果没有"PATH",点击新建一个"PATH"变量名,变量值一样)
第三步:单击Windows xp的“开始”->“运行”,在d出的运行窗口中输入cmd,按回车,打开一个命令行窗口,输入javac,将会看见一系列javac常用参数选项 恭喜你java环境安装成功了
第四步:开始编程(注意先双击打开"我的电脑",在"工具" ->"文件夹选项" -> 点击"查看"选项 ->在"高级设置"中找到"隐藏已知文件类型的扩展名"前面的小勾去掉)。在C盘的根目录中新建一个子目录,名为"JavaTest”,以作为存放 Java源代码的地方。在JavaTest文件夹中,新建文本文档, 把“新建 文本文档txt”改为"HelloWorldjava"。用记事本打开"HelloWorldjava", 输入:
public class HelloWorld {
public static void main(String[] args) {
Systemoutprintln("Hello, world!");
Systemoutprintln("恭喜你成功运行了第一个java应用程序!");
}
}
注意源文件名必须与类名相同,且类修饰符为public,文件名后缀为"java"保存文件
第五步:在命令行窗口中输入 cd C:\JavaTest,将当前路径转入JavaTest目录中。然后,输入 javac HelloWorldjava,JDK就在JavaTest文件夹中编译生成一个HelloWorldclass的类文件。
第六步:在命令行窗口中输入 java HelloWorld,(注意没有class后缀)屏幕出现了
Hello world!
恭喜你成功运行了第一个java应用程序!
表示成功了,也就顺利地编译及运行了第一个Java应用程序。
要运行java程序,我们必须先写一个java程序,由于这里说的仅仅是java程序的运行,所以我就已一个简单的程序来入手了哦!
打开自己的记事本,录入下面的代码:
import javautil;
public class HelloWorld{
public static void main(String[] args){
Systemoutprintln("HelloWorld");
}
}
选择文件---->另存为
文件名称:HelloWorldjava
文件类型:所有文件
在这里要记住自己文件的保存位置哦
为了方便起见,我将自己的第一个java程序保存在了桌面。
打开附件--->命令提示符
键入cd Desktop按下回车键
这步是为了进入桌面,也就是你保存文件的位置
键入javac HelloWorldjava
这步是编译自己的java程序
键入java HelloWorld
这步是为了运行自己的java程序
然后就能看到运行结果了!
Java源程序为java格式的文件,Java程序的运行首先要通过上面提到的javacexe编译程序编译成字节码文件文件后缀为class然后通过jvmJava虚拟机解释运Java的跨平台就是因为各环境有各环境的jvm。因为我们要编写Java程序所以我们需要安装jdk即Java SE Development Kit,意为Java开发工具包它包含javacexe编译程序,tarexe打包程序等只安装Java不能编译执行Java程序,所以我们其实安装的是jdk,安装java只是为了安装jreJava运行环境。
相信大家也知道jdk才是Java的核心下载jdk我建议大家去360软件管家搜索下载,简单方便安装jdk会自动安装java,所以不需要自己单独安装java,如果之前已经安装了java的话在安装jdk进行到安装java的那一步可以点击右上角的关闭退出java的安装。
安装jdk,配置环境变量后编译运行。
1,下载jdk,进oracle官网下载jdk安装包,运行安装。
2,配置环境变量:在系统变量里点击新建,变量名填写JAVA_HOME,变量值填写JDK的安装路径,在这里就填写“C:\Program Files\Java\jdk18”了;在系统变量里点击新建变量名填写CLASSPATH,变量值写“;%JAVA_HOME%\lib;%JAVA_HOME%\lib\toolsjar”。注意不要忘记前面的点和中间的分号;在系统变量里找到Path变量,这是系统自带的,不用新建。双击Path,由于原来的变量值已经存在,故应在已有的变量后加上“;%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin”。注意前面的分号。
打开cmd输入java和javac测试是否成功。
3,编写java代码:
public class Test{
public static void main(String[] args) {
Systemoutprintln("hello");
}
}
另存为Testjava。存放在D盘根目录。
3,编译,打开cmd,输入命令:
D:
切换目录到D盘目录,编译java,输入javac Testjava,编译完成后生成Testclass文件。
4,运行,cmd输入命令:java Test。可以看到运行结果:hello。
Java语言定义了public、protected、private、abstract、static和final这6常用修饰词外还定义了5个不太常用的修饰词,下面是对这11个Java修饰词的介绍:
1public
使用对象:类、接口、成员
介绍:无论它所处在的包定义在哪,该类(接口、成员)都是可访问的
2private
使用对象:成员
介绍:成员只可以在定义它的类中被访问
3static
使用对象:类、方法、字段、初始化函数
介绍:成名为static的内部类是一个顶级类,它和包含类的成员是不相关的。静态方法是类方法,是被指向到所属的类而不是类的实例。静态字段是类字段,无论该字段所在的类创建了多少实例,该字段只存在一个实例被指向到所属的类而不是类的实例。初始化函数是在装载类时执行的,而不是在创建实例时执行的。
4final
使用对象:类、方法、字段、变量
介绍:被定义成final的类不允许出现子类,不能被覆盖(不应用于动态查询),字段值不允许被修改。
5abstract
使用对象:类、接口、方法
介绍:类中包括没有实现的方法,不能被实例化。如果是一个abstract方法,则方法体为空,该方法的实现在子类中被定义,并且包含一个abstract方法的类必须是一个abstract类
6protected
使用对象:成员
介绍:成员只能在定义它的包中被访问,如果在其他包中被访问,则实现这个方法的类必须是该成员所属类的子类。
7native
使用对象:成员
介绍:与 *** 作平台相关,定义时并不定义其方法,方法的实现被一个外部的库实现。
8strictfp
使用对象:类、方法
介绍:strictfp修饰的类中所有的方法都隐藏了strictfp修饰词,方法执行的所有浮点计算遵守IEEE
754标准,所有取值包括中间的结果都必须表示为float或double类型,而不能利用由本地平台浮点格式或硬件提供的额外精度或表示范围。
9synchronized
使用对象:方法
介绍:对于一个静态的方法,在执行之前jvm把它所在的类锁定;对于一个非静态类的方法,执行前把某个特定对象实例锁定。
10volatile
使用对象:字段
介绍:因为异步线程可以访问字段,所以有些优化 *** 作是一定不能作用在字段上的。volatile有时可以代替synchronized。
11transient
使用对象:字段
介绍:字段不是对象持久状态的一部分,不应该把字段和对象一起串起。
以上就是关于如何用java控制一个运行的程序全部的内容,包括:如何用java控制一个运行的程序、运行一个java程序的步骤是怎样的请做详细说明!、如何运行JAVA等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)