欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ubuntu下使用java、javac命令行编译工程

程序员文章站 2022-05-23 10:10:34
...

一、java和javac命令行

(1)javac命令行

javac.exe用于编译java源文件,生成.class文件

语法:javac [option] source

常用的[option]选项:

A、-classpath <路径>(-cp缩写):指定要使用的类路径或要使用的jar包的路径(jar文件、zip文件(里面都是错啦搜索文件)),使用后

会覆盖CLASSPATH的设定

B、-d <路径> :指定源文件编译后生成.class文件的存放位置


(2)java命令行

java.exe用于运行javac编译后生成的.class文件

语法:java [option] classname [arguments]

常用的[option]选项:

A、-classpath <路径>(-cp缩写):指定要使用的类路径或要使用的jar包的路径(jar文件、zip文件(里面都是错啦搜索文件)),使用后

会覆盖CLASSPATH的设定

B、[arguments]:传递给main函数的参数


二、例子

(1)单独一个java程序

Demo.java

public class Demo{
    public static void main(String args[]){
               System.out.println("This is a test");
 }
}

javac Demo.java-----------在当前目录下生成Demo.class文件

java Demo-------------------执行Demo.class


也可以通过-d选项指定生成.class文件的位置,如:

javac -d .. Demo.java ,则就会在当前目录的上一级目录上生成Demo.class文件,那么执行的时候,就要指定class的路径

java -cp .. Demo,表示让java在上一级目录搜索类文件


(2)一个带包的java程序

Demo.java

package com.demo;
public class Demo{
    public static void main(String args[]){
               System.out.println("This is a test");
 }
}
同样,现编译文件:

javac Demo.java-----------在当前目录下生成Demo.class文件

java Demo-------------------执行Demo.class


也可以通过-d选项指定生成.class文件的位置,如:

javac -d . Demo.java-----------按照com.demo的包路径保存.class文件

则会在当前目录下生成一个com/demo/Demo.class文件,如下图:

ubuntu下使用java、javac命令行编译工程

那么在执行的时候,也要指定类文件的路径:

javac com/demo/Demo或者javac com.demo.Demo


(3)同一个包下,一个类调用另一个类

Tom.java

package com.demo;
public class Tom{
 public String getMyname(){
 return "This is Tom!";
}
}

Friend.java

package com.demo;

import com.demo.Tom;

public class Friend{
    public static void main(String args[]){
        Tom tom = new Tom();
        System.out.println("hello "+tom.getMyname());
}
}
由于Friend类条用了Tom类,首先要现编译Tom.java:javac -d . Tom.java,然会会按照包结构生成com/demo/Tom.class文件。

接下来编译Friend.java文件:javac -cp . -d . Friend.java,javac会根据,import com.demo.Tom;这个路径到 -cp 指示的 "."当前目录下寻找,然后按照包结构生成com/demo/Friend.class,见下图:

ubuntu下使用java、javac命令行编译工程

运行:java com.demo.Friend


(4)一个包下的类条用另一个包下的类


Tom.java

package com.demo1;
public class Tom{
 public String getMyname(){
 return "This is Tom!";
}
}

Friend.java

package com.demo2;

import com.demo1.Tom;

public class Friend{
    public static void main(String args[]){
        Tom tom = new Tom();
        System.out.println("hello "+tom.getMyname());
}
}
还是一样,现编译Tom.java,javac -d . Tom.java,生成com/demo1/Tom.class;

然后编译Friend.java,javac -cp . -d . Friend.java,生成com/demo2/Friend.class;

ubuntu下使用java、javac命令行编译工程

运行:java com.demo2.Friend;


(5)更接近项目的java工程

一般,一个工程下面都会有lib(引入的必要jar包),classes(保存.class文件),src(.java源代码)三个文件夹。

java文件夹的目录结构如下,文件之间的关系是Client.java调用了DemoService.java的方法;ServerImpl.java调用了DemoService.java的方法;Server.java调用了ServerImpl.java和DemoService.java的方法;

ubuntu下使用java、javac命令行编译工程

下面的文件,我只显示他们引用的包和类。

src/com/client/Client.java:

package com.client;
import org.apache.thrift.TException;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport;

import com.demo.DemoService;
 

public class Client {
	
	.................................................................................

}
src/com/demo/DemoService.java:
/**
 * Autogenerated by Thrift Compiler (0.9.0)
 *
 * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING
 *  @generated
 */

package com.demo;
import org.apache.thrift.scheme.IScheme;
import org.apache.thrift.scheme.SchemeFactory;
import org.apache.thrift.scheme.StandardScheme;

import org.apache.thrift.scheme.TupleScheme;
import org.apache.thrift.protocol.TTupleProtocol;
import org.apache.thrift.protocol.TProtocolException;
import org.apache.thrift.EncodingUtils;
import org.apache.thrift.TException;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.util.HashMap;
import java.util.EnumMap;
import java.util.Set;
import java.util.HashSet;
import java.util.EnumSet;
import java.util.Collections;
import java.util.BitSet;
import java.nio.ByteBuffer;
import java.util.Arrays;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class DemoService {
.................................................................
}
src/com/server/Server.java:

package com.server;
import org.apache.thrift.TProcessor;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.server.TServer;
import org.apache.thrift.server.TSimpleServer;
import org.apache.thrift.transport.TServerSocket;
import org.apache.thrift.transport.TTransportException;

import com.demo.DemoService;
import com.server.ServerImpl;

public class Server {
	
..................................................................................

}

make.sh脚本如下:

#!/bin/bash

# Get current position
TOP_DIR=$(pwd)

# Add all necessary jars
LIBPATH=lib/commons-codec-1.6.jar:lib/commons-logging-1.1.1.jar:lib/httpclient-4.2.5.jar:lib/httpcore-4.2.4.jar:lib/junit-4.4.jar:lib/libthrift-1.0.0.jar:lib/log4j-1.2.14.jar:lib/servlet-api-2.5.jar:lib/slf4j-api-1.5.8.jar:lib/slf4j-log4j12-1.5.8.jar

#compile java file
javac -cp $LIBPATH                  src/com/demo/DemoService.java  -d ./classes/. 
javac -cp $TOP_DIR/classes:$LIBPATH src/com/server/ServerImpl.java -d ./classes/.
javac -cp $TOP_DIR/classes:$LIBPATH src/com/server/Server.java     -d ./classes/.
javac -cp $TOP_DIR/classes:$LIBPATH src/com/client/Client.java     -d ./classes/.

run.sh脚本如下:

#!/bin/bash

#Get client/server
SIDE=$1

# Get current position
TOP_DIR=$(pwd)

# Add all necessary jars
LIBPATH=lib/commons-codec-1.6.jar:lib/commons-logging-1.1.1.jar:lib/httpclient-4.2.5.jar:lib/httpcore-4.2.4.jar:lib/junit-4.4.jar:lib/libthrift-1.0.0.jar:lib/log4j-1.2.14.jar:lib/servlet-api-2.5.jar:lib/slf4j-api-1.5.8.jar:lib/slf4j-log4j12-1.5.8.jar

#run program
if [ $SIDE == "server" ];then
    java -cp $TOP_DIR/classes:$LIBPATH  com/server/Server
else
    java -cp $TOP_DIR/classes:$LIBPATH  com/client/Client
fi

进入thriftDemo文件夹下,执行./make.sh脚本,在classes文件夹下生成的文件如下:

ubuntu下使用java、javac命令行编译工程



参考:wenku.baidu.com/view/f4c19dbc65ce0508763213c6.html