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

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

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

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

package mypack;
public class A {
    String name;
    int age;
    public void setName(String _name){
        this.name =_name;
    }
    public void setAge(int _age){
        this.age = _age;
    }
    public String getName(){
        return this.name;
    }
    public int getAge(){
        return this.age;
    }
    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());
    }
}

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

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

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

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

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

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

这下就可以成功执行了!

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

这次我们引入另外一个测试类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());
	}
}

  

  编译执行如下:

结果意料之中肯定是能够编译执行的,执行流程是这样的: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命令的参数是“类的完整类名”,而不是“文件名”。

因此我们需要这样执行:

这样就

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

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

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

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

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

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

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

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

时间: 2024-12-04 04:24:04

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

Java中的包

以下内容引用自http://wiki.jikexueyuan.com/project/java/packages.html: 在Java中使用包是为了防止命名冲突,来控制访问,使得搜索/定位和类.接口.枚举和注释等的使用更为简单. 包可以被定义为一组相关的类型(类.接口.枚举和注释),提供访问保护和命名空间管理. 在Java中一些已经存在的包有: java.lang - 包含了基本类 java.io - 包含有输入,输出功能的类 程序员可以定义自己的包来包含各种类和接口等.把实现的相关类组织在一

Java基础---Java中带参数无返回值方法的使用(三十九)

Java 中带参无返回值方法的使用 有时方法的执行需要依赖于某些条件,换句话说,要想通过方法完成特定的功能,需要为其提供额外的信息才行.例如,现实生活中电饭锅可以实现"煮饭"的功能,但前提是我们必须提供食材,如果我们什么都不提供,那就真是的"巧妇难为无米之炊"了.我们可以通过在方法中加入参数列表接收外部传入的数据信息,参数可以是任意的基本类型数据或引用类型数据. 我们先来看一个带参数,但没有返回值的方法: 上面的代码定义了一个 show 方法,带有一个参数 name

java中的“包”与C#中的“命名空间

原文地址:http://www.cnblogs.com/lidabo/archive/2012/12/15/2819865.html Package vs. Namespace 我们知道,重用性(reusebility)是软件工程中一个非常重要的目标.重用,不仅仅指自己所写的软件(代码.组件等等)可以被重复利用:更广义的重用是指不同的人,不同的团队,不同的公司之间可以互相利用别人的成果.另外,对于大型软件,往往是由多个团队共同开发的,这些团队有可能分布于不同的城市.地区.甚至国家.由于这些原因,

Java中的包(package)

包的概念 Java中包(package)的概念和C++中命名空间(namespace)的概念很类似,都可以限制类的作用域.二者最大的差别在于,Java中的包隐式地指明了类的树形层级结构(同时也是Java源码文件的目录结构).这样做的好处在于:可以通过文件系统中对于文件路径唯一性的要求来限制类的唯一性. 代码组织 编写一个Java源代码文件(.java文件)时,此文件通常被称为编译单元.在编译单元内最多允许有一个public类,且该类的名称必须与文件名完全相同(包括大小写). 编译一个.java文

java中的包(package)

Java中的包在一定程度上类似于C++的命名空间,可以用于防止类名冲突.Java自带的类都位于java和javax包层次中,但引入时不能使用import java.*或import javax.*. 当遇到同时使用几个不同包下名称相同的类时,在使用的地方可以直接加上包路径以防止冲突,如 java.util.Date date=new java.util.Date date(); 静态导入 import static java.lang.Math ,则可直接使用Math的静态方法,如sqrt(a)

深刻理解Java中形参与实参,引用与对象的关系

声明:本博客为原创博客,未经允许,不得转载!原文链接为http://blog.csdn.net/bettarwang/article/details/30989755 我们都知道,在Java中,除了基本数据类型之外,其他的都是引用类型,当它们作为函数参数时,传递的也是引用,通过引用可以改变对象的值,很多人便因此而忽略形参与实参,引用与对象的关系问题.废话不多说,先看下面一个例子: import java.util.*; public class Student { private String

Java基础---Java中带参数返回值方法的使用(四十)

Java 中带参带返回值方法的使用 如果方法既包含参数,又带有返回值,我们称为带参带返回值的方法. 例如:下面的代码,定义了一个 show 方法,带有一个参数 name ,方法执行后返回一个 String 类型的结果 调用带参带返回值的方法: 运行结果: 代码: import java.util.Arrays; public class HelloWorld {    public static void main(String[] args) {  HelloWorld hello = new

Java中的值传递与“引用传递”

首先,Java没有 引用传递 这么一说. Java只有值传递,传递的都是值,基本数据类型传递的是值,引用类型传递的是地址值. 我来理一下这其中犹如米线跟米面绞在一起了,再跟粉丝混在一起的关系. 好的,我们来看第一个例子: public static void main(String[] args) { int a = 1; int b = 4; System.out.println("Before : a=" + a + "," + "b=" +

java中内部类的创建四种情况,三种方式,及内部数据访问权限

内部类和外部类的关系,及内部静态类的数据访问权限,声明方式. 第一种,在外部类内部声明使用内部类,内部类的类型为static和非 static类型,内部类数据类型为private,protected,public 类型的访问权限.外部类为非静态声明和权限如下: package com; public class Test1 { //@author 张春蕾 private class Name{ private int i =1; public int s = 2; protected int m