java创建包_Java中带包(创建及引用)的类的编译

本文介绍了在Java中如何处理带有包声明的类的编译和调试。当类包含包声明时,直接使用`javac`命令编译将导致错误,需要使用`javac -d .`进行打包编译。执行时,应提供类的完整类名。文章还讨论了包的导入、多文件编译以及当类路径不在当前目录下时如何设置`classpath`。
摘要由CSDN通过智能技术生成

Java中带包(创建及引用)的类的编译与调试

java源程序的编译大家都知道,也就是cmd中到源文件所在目录下javac **.java即可,当程序中有包声明还能简简单单的直接javac **.java吗?答案当然是no,下面举个简单的例子证明一下直接javac **.java会怎么样。

如下:F:\javaweb2班\20160531目录下有A.java文件,注意源文件中有包声明

package mypack;public classA {

String name;intage;public voidsetName(String _name){this.name =_name;

}public void setAge(int_age){this.age =_age;

}publicString getName(){return this.name;

}public intgetAge(){return this.age;

}public static voidmain(String[] args){

A a= newA();//a.setName("zs");

a.name="zs";

a.setAge(18);

System.out.println(a.getName()+a.getAge());

}

}

415eebcaa1d73a0a7653261bcf57ce6e.png

现在对A.java直接进行编译javac A.java结果如下:

88faad54c1797d8697f3c38058880089.png

我们可以清楚地看到当前目录下出现了A.class字节码文件,就这样能不能直接运行呢?试试吧!

9fc6b92d81953428075da1655ae1112c.png

出现了这样的错误,原因是我们在A.java中有包声明,当执行A.java源文件时java虚拟机首先会在A.java当前目录寻找字节码文件,虽然这下找到了,但是因为在A.java中有包声明,java虚拟机紧接着去包目录下寻找有没有A.class字节码文件,这下找到了才能够成功执行,不信我们做做实验!(这里我再教教大家怎么编译有包声明的A.java,也就是打包编译javac -d . A.java即可)

60846fa78f37b1d2a0b17d7f91b1379c.png

这下就打包编译成功了,这时我们可以看到mypack目录下出现了A.class文件,下面试试执行吧

ee401bd15e9f5e6f5eac66b6e8034ed0.png

这时我们发现执行还是不能通过??这时为什么呢?这里是许多新手遇到的问题,在这里大家必须谨记一点:Java命令的参数是“类的完整类名”,而不是“文件名”。

这个源程序的完整类名应该是mypack.A,因此应该这么写:java mypack.A

3febb83928c5bf550be7346841e08b28.png

这下就可以成功执行了!

别急!!下面还有更精彩的!作为包的使用怎么可能会不讲解一下包的导入创建编译呢!

这次我们引入另外一个测试类Test.java,代码如下:

import mypack.A;

public class Test{

public static void main(String[] args){

A a = new A();

a.setName("zs");

//a.name="zs";

a.setAge(18);

System.out.println(a.getName()+a.getAge());

}

}

编译执行如下:

6c09f5bdc04923324df8c14f240dd814.png

结果意料之中肯定是能够编译执行的,执行流程是这样的:Test.java编译之后生成的字节码文件在当前目录(编译时他会寻找mypack中是否有A.class文件,若无,编译不通过),执行时,由于Test.java中没有包声明,java虚拟机首先在当前目录找到Test.class就会执行,执行到程序中引用到A类的地方,然后java虚拟机在当前目录看是否有A.class字节码文件,这时即使发现了也会根据源程序中的包导入进入包中寻找A.class,找到才能执行成功(其实在编译阶段就已经寻找了!)

下面更进一步:若我们给测试类Test.java加上包声明package mypack1;

这时我们对Test.java进行打包编译,这里我又要给大家讲解两个知识点:1.打包编译时,会自动创建包目录,不需要自己新建包名文件夹;2.当当前目录有多个java文件需要编译或打包编译时,javac -d . *.java指令可以给当前目录下的所有java文件根据程序中是否有包声明进行编译或打包编译

这时我们又该如何执行Test.java文件呢?java Test.java吗??显然这样是不行的,还记得我前面讲过的么:Java命令的参数是“类的完整类名”,而不是“文件名”。

因此我们需要这样执行:

796a4fa00a519800f12d2bbab31cde5e.png

这样就

上面讲的这些都是一般情况,也就是类路径都是在当前目录下,当类路径不在当前目录下是否还能执行呢?又该如果执行呢?

如下图我把Test.java放到外面一层目录,这时我们就需要自己设置classpath参数。例如:F:\javaweb2班>java -cp F:/javaweb2班/20160531 mypack1.java;或者在任意目录下:java -cp F:/javaweb2班/20160531 mypack1.java

0a72add836a3d756fc5e04d800b73ee4.png

这样就成功了!具体的执行流程大家自己分析体会吧!

总结一下:1.Java命令的参数是“类的完整类名”,而不是“文件名”。

2.打包编译时,会自动创建包目录,不需要自己新建包名文件夹。

3.当当前目录有多个java文件需要编译或打包编译时,javac -d . *.java指令可以给当前目录下的所有java文件根据程序中是否有包声明进行编译或打包编译。

4.当类路径不在当前目录下时,需要用到java -cp ...如:java -cp F:/javaweb2班/20160531 mypack1.java。

5.要清楚java虚拟机根据包声明包导入执行字节码文件的流程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值