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

一、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文件,如下图:

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

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,见下图:

运行: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;


运行: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的方法;

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

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文件夹下生成的文件如下:



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







猜你喜欢

转载自blog.csdn.net/wen294299195/article/details/39964971