编译java命令_命令行编译Java

命令行编译Java

标签(空格分隔): Java

Java代码:

/* a.java */

package com.pepelu.test;

public class a{

public static void main(String[] args){

System.out.println("hello shell");

}

}

类名要和文件名一致,不然会报错(找不到类啊什么的)。

编译,生成class文件:

javac -target 1.7 -source 1.7 -bootclasspath E:\environment\adt\sdk\platforms\android-20\android.jar -d E:\workspace\EclipseAndroid\test_pkg_out\classes E:\workspace\EclipseAndroid\HelloWorld\src\com\example\helloworld\*.java E:\workspace\EclipseAndroid\test_pkg_out\RFile\com\example\helloworld\R.java

-target 生成特定 VM 版本的类文件(可以不要)

-source 1.7 要求編譯器檢查使用的語法不超過指定的版本

-bootclasspath Bootstrap類別載入器(Class loader)

-d 指定存放生成的类文件的位置,生成package的目录结构

-sourcepath 指定查找输入源文件的位置

因为Android目前不支持jdk1.8,所以如果使用的jdk的版本大于1.7,编译Java文件时要加入:-target 1.7 ,JDK8預設的-target與-source都是1.8,-target在指定時,值必須大於或等於-source,所以在上面,若只指定-target為1.7,就會無法通過編譯,因為-source仍是預設值1.8。

简化版:

javac -d E:\workspace\java\temp E:\workspace\java\temp\a.java

-d 指定存放生成的类文件的位置,生成package的目录结构

-sourcepath 指定查找输入源文件的位置,如果把命令行光标移到所在目录,则文件名前的目录可以省略,如果有多个文件,用空格分隔

javac -d classes a.java b.java

自动生成对应包名的文件目录

更简化版:

javac -d . JavaFileName

在当前目录生成package结构的class文件。

执行a.class

执行前把shell定位到package开始目录

java com.pepelu.test.a

保存输出:

java com.pepelu.test.a >save.data

把输出保存到save.data文件中。

打包jar:

jar cvf [生成jar的名称.jar] [列出class文件] //若有多个用空格隔开

把控制台定位到package名对应的起始目录

jar -cvf a.jar .

"." 代表当前目录,文件名可加目录

升级版:在任意目录打指定目录的jar包

jar -cvf a.jar -C E:\workspace\java\temp\classes .

-C: 先执行 cd E:\workspace\java\temp\classes , 再执行 jar -cvf a.jar .,但*.jar文件保存在shell光标所在文件目录。

执行jar包中的class文件

java -cp a.jar com.pepelu.test.a

-cp : 进入到jar包内执行 com.pepelu.test.a

引用其他jar包,编译:

/* b.java */

package net.pepelu.test;

public class b{

public String f1(){

System.out.println("this is b.class");

return "no bb";

}

}

/* c.java */

package com.pepelu.test;

import net.pepelu.test.b;

public class c{

public static void main(String[] args){

b _b=new b();

_b.f1();

System.out.println("------------------");

}

}

编译:

//生成class文件,b.java,c.java 同时编译:

javac -d classes a.java b.java

//分文件编译,先编译b.java生成jar包,再编译a.java

javac -cp jarFileName JavaFileName -d classes

引用其他jar包,执行

执行:执行前把shell定位到package开始目录

//CMD:

java -cp b.jar;c.jar; com.pepelu.test.c

//PowerShell:

java -cp 'b.jar;c.jar;' com.pepelu.test.c

jar包最后要加“;”

jar包顺序可变

在PowerShell中,把 b.jar;加单引号或双引号,因为PowerShell是面向对象的命令行,所以会把b.jar看做是一个文件对象,而Java需要接收的是一个jar文件地址字符串,所以要加引号把b.jar;转为字符串“;”号必须加。

http://stackoverflow.com/questions/4685184/powershell-run-java-process-problem

多jar包:

假设有个程序的启动方法在test.java里

运行Java程序是java test,但是如果要引用其他jar包,网上大多数的方法都是java -classpath xx.jar test

但是jar很多的话,就要一个一个写上去,非常麻烦。而且jar包可能经常变

现在用以下一句就能解决问题,假设jar包都放在lib文件夹里

编译:

//CMD:

javac -Djava.ext.dirs=lib test

//PowerShell :

javac '-Djava.ext.dirs=lib' com.pepelu.test.c

执行:

//CMD:

java -Djava.ext.dirs=lib test

//PowerShell :

java '-Djava.ext.dirs=lib' com.pepelu.test.c

注意:要JDK1.6以上才可以

打包,配置 META-INF

/* MANIFEST.MF */

Manifest-Version: 1.0

Created-By: pepelu

Class-Path: com.pepelu.test

Main-Class: com.pepelu.test.a

(此处为空行)

第一行指定清单的版本,若无,则JDK默认生成:Manifest-Version: 1.0

第二行指明创建的作者,若无,则JDK默认生成Created-By: 1.6.0_22(Sun Microsystems Inc.)

第三行指定主类所在类路径

第四行指明程序运行的主类

在文件最后要加一行空行

打包:

jar -cvfm a.jar MANIFEST.MF -C classes .

-m : 指定MANIFEST.MF文件

如果MANIFEST.MF末尾不加空行,则要重新指定主类所在类路径

jar -cvfme a.jar MANIFEST.MF com.pepelu.test.a -C classes .

运行:

java -jar a.jar

补充:

主函数mian是可以传参的:

public static void main(String[] args)

命令行执行:

java com.pepelu.test.a blabla

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值