Java基础_面向对象(异常2、练习题、导包)


一、面向对象(异常-finally

finally代码块:定义一定要执行的代码,通常用于关闭资源。

/*
举例:操作数据库。
1.连接
2.操作
3.关闭
*/
import java.sql.SQLException;//引入SQL包的SQLException类
class NoException extends Exception
{
	NoException(String msg)
	{
		super(msg);
	}
}
class Demo
{
	public void method()throws NoException
	{
		try
		{
			System.out.println("连接数据库");//连接数据库

			System.out.println("数据库操作");//数据库操作
			throw new SQLException();//假设出现数据库操作异常

		}
		catch (SQLException e)
		{
			System.out.println("会对数据库进行异常处理");
			throw new NoException("数据操作失败");
		}
		finally
		{
			System.out.println("关闭数据库");//无论操作数据操作是否成功,都应关闭资源。
		}
	}
}

class ExceptionDemo5 
{
	public static void main(String[] args) 
	{
		
		try
		{
			new Demo().method();
		}
		catch (NoException e)
		{
			System.out.println(e.toString());
		}
		finally
		{
			System.out.println("结束");//一定会执行的代码
		}
		
	}
}


二、面向对象(异常-处理语句其他格式)

第一个格式:

try

{

}

catch ()

{

}

第二个格式:

try

{

}

catch ()

{

}

finally

{

}

第三个格式:

try

{

}

finally 

{

}

注意:catch是用于处理异常的,如果没有catch则代表异常没有被处理。

如果该异常是检测时异常,则必须声明。

/*
例子:
*/
class Demo
{
	public void method()throws Exception
	{
		try
		{
			throw new Exception("异常");
		}
		finally
		{
			//关闭资源。
		}
	}
}
class ExceptionDemo6 
{
	public static void main(String[] args) 
	{
		try
		{
			new Demo().method();
		}
		catch (Exception e)
		{
			System.out.println(e.toString());
		}
		
	}
}


三、面向对象(异常-覆盖时的异常特点)

1.子类在覆盖父类时:如果父类的方法抛出异常,那么子类的覆盖方法只能抛出父类的异常或者该异常的子类。

2.如果父类方法抛出多个异常,那么子类在覆盖该方法时只能抛出父类异常的子集。

3.如果父类或者接口的方法中没有异常的抛出,那么子类在覆盖该方法时也不可以抛出异常。如果子类方法发生了异常,就必须进行try处理,绝对不能抛。

四、面向对象(异常-练习)

/*
有一个圆形和长方形,它们都可以获取面积,对于面积如果出现非法的数值视为是
获取面积时出现的问题。问题用异常表示。
*/
class NoValueException extends RuntimeException
{
	NoValueException(String msg)
	{
		super(msg);
	}
}
interface Shape
{
	void getArea();
}

class Rec implements Shape
{
	private double len,wid;

	Rec(double len,double wid)
	{
		if(len<=0||wid<=0)
			throw new NoValueException("出现非法值");

		this.len=len;
		this.wid=wid;
	}
	public void getArea()
	{
		System.out.println("面积:"+len*wid);
	}
}
class Circle implements Shape
{
	private double radius;
	public static final double PI=3.141592653;
	Circle(double radius)
	{
		if(radius<=0)
			throw new NoValueException("出现非法值"); 
		this.radius=radius;
	}
	public void getArea()
	{
		System.out.println("面积:"+PI*radius*radius);
	}

}
class ExceptionTest1 
{
	public static void main(String[] args) 
	{
		new Rec(-3,4).getArea();
		new Circle(8).getArea();
		System.out.println("结束");

	}
}


 

五、面向对象(异常-总结)

异常:

定义:是对问题的描述,将问题进行对象的封装。

-----------------------------------------

异常体系:

Throwable

      |------Error

      |------Exception

                     |------RuntimeException

异常体系的特点:异常体系中的所有类以及建立的对象都具备可抛性。也就是说可以被throwthrows关键字所处理。只有异常体系具备这个特点。

-----------------------------------------

throwthrows的用法:

throw:定义在函数内,用于抛出异常对象。

throws:定义在函数上,用于抛出异常类,可以抛出多个,用逗号隔开。

当函数内容有throw抛出异常对象,并未进行try处理,则必须要在函数上声明,否则编译失败。

注意:RuntimeException除外,也就是说,函数内如果抛出的是RuntimeException异常,函数上可以不用声明。

-----------------------------------------

如果函数声明了异常,调用者需要进行处理:throwstry

异常有两种:

编译时被检测异常:该异常在编译时,如果没有处理(没有throws也没有try),编译失败。

该异常被标识,代表这可以被处理。

运行时异常(编译时不检测):在编译时不需要处理,编译器不检查。该异常的发生,建议不处理,让程序停止。需要对代码进行修正。

-----------------------------------------

异常处理语句:

try

{

需要被检测的代码;

}

catch (异常类 变量)

{

处理异常的代码(处理方式);

}

finally

{

一定会执行的语句;

}

-----------------------------------------

有三种结合格式:

第一个格式:

try

{

}

catch ()

{

}

第二个格式:

try

{

}

catch ()

{

}

finally

{

}

第三个格式:

try

{

}

finally 

{

}

注意:

1.finally中定义的通常是关闭资源代码,因为资源必须要释放。

2..finally只有一种情况不会执行,那就是当执行到System.exit(0);的时候。

-----------------------------------------

自定义异常:

定义类继承ExceptionRuntimeException

1.为了让该自定义类具有可抛性。

2.让该类具备操作异常的共性方法。

当要定义自定义异常的信息时,可以使用父类已经定义好的功能,将异常信息传递给父类的构造函数。

class MyException extends Exception
{
	MyException(String msg)
	{
		super(msg);
	}
}


自定义异常出现的好处:

自定义异常是按照Java面向对象的思想,将程序中出现的特有问题进行封装。

-----------------------------------------

异常的好处:

1.将问题封装。

2.将正常流程代码和问题处理代码相分离,方便阅读。

异常处理的原则:

1.处理方式有两种:trythrows

2.调用到抛出异常的功能时,抛出几个就处理几个。

3.多个catch:父类的catch放在最下面。

4.catch内需要定义针对性的处理方式,不要简单定义printStackTrace和输出语句,也不要不写。

 当捕获到的异常,本功能处理不了可以继续在catch中抛出。

  try
  {
  	throw new AException();
  }
  catch (AException e)
  {
  	throw e;
  }


 

如果该异常处理不了,但并不属于该功能出现的异常。可以将异常转换后,再抛出和该功能相关的异常。

或者异常可以处理,当需要将异常产生的和本功能相关的问题提供出去,让调用者知道并处理。也可以将捕获异常处理后,转换新的异常。

try
{
	throw new AException();
}
catch (AException e)
{
	//对AException先处理

	throw new BException();
}


 

比如汇款的例子。

张三给李四汇款时,银行发现李四用户名错误,在报错之前应该先进行处理,把钱先返回到张三的账户,然后在提示用户名错误的信息。

异常的注意事项:

子类在覆盖父类时:

1.子类抛出的异常必须是父类的异常的子类或子集。

2.如果父类或者接口没有异常抛出时,子类覆盖出现异常,只能try不能抛。

六、练习

/*
注:按Java规范书写程序代码,如果你认为程序有错误,请指出并说明程序错误的原因。

*/

/*1.
class Demo
{
	public static void func()
	{
		try
		{
			throw new Exception();
		}
		finally
		{
			System.out.println("B");
		}
	}

	public static void main(String[] args)
	{
		try
		{
			func();
			System.out.println("A");
		}
		catch (Exception e)
		{
			System.out.println("C");
		}
		System.out.println("D");
	}
}
编译无法通过。
给func加上声明throws Exception,结果是:
B
C
D
*/


/*2.
class Test
{
	Test()
	{
		System.out.println("Test");
	}
}
class Demo extends Test
{
	Demo()
	{
		super();
		System.out.println("Demo");
	}
	public static void main(String[] args)
	{
		new Demo();
		new Test();
	}
}

Test
Demo
Test
考的是子类的实例化过程。
*/


/*3.
interface A
{
}
class B implements A
{
	public String func()
	{
		return "func";
	}
}
class Demo
{
	public static void main(String[] args)
	{
		A a=new B();
		System.out.println(a.func());
	}
}

编译失败:因为A接口中并未定义func方法。
*/
/*4.
写出程序结果:

class Fu
{
	boolean show(char a)
	{
		System.out.println(a);
		return true;
	}
}
class Demo extends Fu
{
	public static void main(String[] args)
	{
		int i=0;
		Fu f=new Demo();
		Demo d=new Demo();
		for(f.show('A');f.show('B')&&(i<2);f.show('C'))
		{
			i++;
			d.show('D');
		}
	}
	boolean show(char a)
	{
		System.out.println(a);
		return false;
	}
}

A
B

*/
/*5.
interface A
{
}
class B implements A
{
	public String test()
	{
		return "yes";
	}
}
class Demo
{
	static A get()
	{
		return new B();
	}
	public static void main(String[] args)
	{
		A a=get();
		System.out.println(a.test());
	}
}
编译失败,A接口中没有定义test方法。
*/
/*6.
class Super
{
	int i=0;
	public Super(String a)
	{
		System.out.println("A");
		i=1;
	}
	public Super()
	{
		System.out.println("B");
		i+=2;
	}
}
class Demo extends Super
{
	public Demo(String a)
	{
		//super();
		System.out.println("C");
		i=5;
	}
	public static void main(String[] args)
	{
		int i=4;
		Super d=new Demo("A");
		System.out.println(d.i);
	}
}


B
C
5

*/

/*7.
interface Inner
{
	void show(int a,int b);
	void func();
}
class Demo
{
	public static void main(String[] args)
	{
		//补足代码:调用两个函数,要求用匿名内部类
		Inner in=new Inner()
		{
			public void show(int a,int b)
			{
			}
			public void func()
			{
			}
		};
		in.show();
		in.func();
	}
}
*/
/*8.
class TD
{
	int y=6;
	class Inner
	{
		static int y=3;
		void show()
		{
			System.out.println(y);
		}
	}
}
class TC
{
	public static void main(String[] args)
	{
		TD.Inner ti=new TD().new Inner();
		ti.show();
	}
}
编译失败。
非静态内部类中不可以定义静态成员。内部类中如果定义了静态成员,该内部类
必须被静态修饰。

*/
/*9.

选择题,写出错误答案的错误原因,用单行注释的方式。
class Demo
{
	int show(int a,int b){return 0;}
}
下面哪些函数可以存在于Demo的子类中?
A.public int show(int a,int b){return 0;}//可以,覆盖。
B.private int show(int a,int b){return 0;}//不可以,权限不够
C.private int show(int a,long b){return 0;}//可以,函数的重载,不是覆盖。
D.public short show(int a,int b){return 0;}//不可以,因为该函数不可以和给定函数在同一类中或者子父类中。
E.static int show(int a,int b){return 0;}//不可以,静态只能覆盖静态。

*/

/*10.

写出this关键字的含义,final有哪些特点?

this:代表本类对象,哪个对象调用this所在函数,this就代表哪个对象。
final:
1.修饰类,变量(成员变量,静态变量,局部变量),函数。
2.修饰的类不可以被继承。
3.修饰的函数不可以被覆盖。
4.修饰的变量是一个常量,只能赋值一次。
5.局部内部类只能访问局部当中的final类型变量。

*/

/*11.
写出程序运行结果:
class Fu
{
	int num=4;
	void show()
	{
		System.out.println("showFu");
	}
}
class Zi extends Fu
{
	int num=5;
	void show()
	{
		System.out.println("showZi");
	}
}
class T
{
	public static void main(String[] args)
	{
		Fu f=new Zi();
		Zi z=new Zi();
		System.out.println(f.num);
		System.out.println(z.num);
		f.show();
		z.show();
	}
}

4
5
showZi
showZi

*/
/*12.
interface A
{
	void show();
}
interface B
{
	void add(int a,int b);
}
class C implements A,B
{
	//程序代码
	private int sum;
	public void show()
	{
		System.out.println(sum);
	}
	public void add(int a,int b)
	{
		sum=a+b;
	}
}
class D
{
	public static void main(String[] args)
	{
		C c=new C();
		c.add(4,2);
		c.show();//通过该函数打印以上两个数的和。
	}
}

*/

/*13.
写出程序运行结果:
class Demo
{
	public static void main(String[] args)
	{
		try
		{
			showExce();
			System.out.println("A");
		}
		catch (Exception e)
		{
			System.out.println("B");
		}
		finally
		{
			System.out.println("C");
		}
		System.out.println("D");
	}
	public static void showExce()throws Exception
	{
		throw new Exception();
	}
}

B
C
D

*/

/*14.
写出程序运行结果:
class Super
{
	int i=0;
	public Super(String s)
	{
		i=1;
	}
}
class Demo extends Super
{
	public Demo(String s)
	{
		i=2;
	}
	public static void main(String[] args)
	{
		Demo d=new Demo("yes");
		System.out.println(d.i);
	}
}

编译失败。因为父类中缺少空参数的构造函数。
或者子类应该通过super语句指定要调用的父类中的构造函数。

*/

/*15.

写出程序运行结果:
class Super
{
	public ing get(){return 4;}
}
class Demo15 extends Super
{
	public long get(){return 5;}
	public static void main(String[] args)
	{
		Super s=new Demo15();
		System.out.println(s.get());
	}
}

编译失败。因为父类中的get方法没有覆盖。但是子类调用时不能明确
返回值类型。

*/

/*16.
class Demo
{
	public static void func()
	{
		try
		{
			throw new Exception();
			System.out.println("A");
		}
		catch (Exception e)
		{
			System.out.println("B");
		}
	}

	public static void main(String[] args)
	{
		try
		{
			func();
		}
		catch (Exception e)
		{
			System.out.println("C");
		}
		System.out.println("D");
	}
}

编译失败,因为打印"A"的输出语句执行不到。
*/

/*17.
class Demo
{
	public void func()
	{
		//位置1
	}
	class Inner{}
	public static void main(String[] args)
	{
		Demo d=new Demo();
		//位置2
	}
}
A.在位置1写 new Inner();//正确
B.在位置2写 new Inner();//错误。因为主函数是静态的。如果要访问Inner,需要被static修饰。
C.在位置2写 new d.Inner();//错误。 new new Demo().Inner();
D.在位置2写 new Demo.Inner();//错误。因为Inner不是静态的。

*/

/*18.
写出程序运行结果:
class Exc0 extends Exception{}
class Exc1 extends Exc0{}
class Demo
{
	public static void main(String[] args)
	{
		try
		{
			throw new Exc1();
		}
		catch (Exception e)
		{
			System.out.println("Exception");
		}
		catch (Exc0 e)
		{
			System.out.println("Exc0");
		}
	}
}

编译失败。因为多个catch时,父类的catch要放在最下面。

*/

/*19.
interface Test
{
	void func();
}
class Demo
{
	public static void main(String[] args)
	{
		//补足代码(匿名内部类)
		new Demo().show(new Test()
		{
			public void func(){};
		});
	}
	void show(Test t)
	{
		t.func();
	}
}

*/

/*20.
写出程序运行结果:
class Test
{
	public static String output="";
	public static void foo(int i)
	{
		try
		{
			if(i==1)
				throw new Exception();
			output+="1";
		}
		catch (Exception e)
		{
			output+="2";
			return;
		}
		finally
		{
			output+="3";
		}
		output+="4";
	}
	public static void main(String[] args)
	{
		foo(0);
		System.out.println(output);
		foo(1);
		System.out.println(output);
	}
}

13423

*/

/*21.
建立一个图形接口,声明一个面积函数。圆形和矩形都实现这个接口,并得出两个图形的面积。
注:体现面向对象的特征,对数值进行判断。用异常处理。不合法的数值要出现"数值是非法的"
提示,不再进行运算。

class NoValueException extends RuntimeException
{
	NoValueException(String msg)
	{
		super(msg);
	}
}
interface Shape
{
	void getArea();
}

class Rec implements Shape
{
	private double len,wid;

	Rec(double len,double wid)
	{
		if(len<=0||wid<=0)
			throw new NoValueException("数值是非法的");

		this.len=len;
		this.wid=wid;
	}
	public void getArea()
	{
		System.out.println("面积:"+len*wid);
	}
}
class Circle implements Shape
{
	private double radius;
	public static final double PI=3.141592653;
	Circle(double radius)
	{
		if(radius<=0)
			throw new NoValueException("数值是非法的"); 
		this.radius=radius;
	}
	public void getArea()
	{
		System.out.println("面积:"+PI*radius*radius);
	}

}
class ExceptionTest1 
{
	public static void main(String[] args) 
	{
		new Rec(-3,4).getArea();
		new Circle(8).getArea();
		System.out.println("结束");

	}
}

*/

/*22.
补足compare函数内的代码,不许添加其它函数。
class Circle
{
	private static double pi=3.14;
	private double radius;
	public Circle(double r)
	{
		radius=r;
	}
	public static double compare(Circle[] cir)
	{
		//程序代码。其实就是在求数组中的最大值。
		double max=cir[0].radius;
		for(int i=1;imax)
			{
				max=cir[i].radius;
			}
		}
		return max;
	}
}
class TC
{
	public static void main(String[] args)
	{
		Circle cir[]=new Circle[3];//创建了一个类类型数组
		cir[0]=new Circle(1.0);
		cir[1]=new Circle(2.0);
		cir[2]=new Circle(4.0);
		System.out.println("最大的半径值是:"+Circle.compare(cir));
	}
}

*/

/*23.
写出程序运行结果:
public class Demo
{
	private static int j=0;
	private static boolean methodB(int k)
	{
		j+=k;
		return true;
	}
	public static void methodA(int i)
	{
		boolean b;
		b=i<10|methodB(4);
		b=i<10||methodB(8);
	}
	public static void main(String[] args)
	{
		methodA(0);
		System.out.println(j);
	}

}

4

*/

/*24.

开发一个系统,需要对员工进行建模,员工包含3个属性:
姓名,工号以及工资。经理除员工具有的属性外,另外还有一个奖金属性。
使用继承思想设计出员工类和经理类。要求类中提供必要的方法进行属性
访问。

abstract class Employee
{
	private String name;
	private String id;
	private double pay;

	Employee(String name,String id,double pay)
	{
		this.name=name;
		this.id=id;
		this.pay=pay;
	}

	public String getName(){return name;}
	public String getId(){return id;}
	public double getPay(){return pay;}

	public abstract void work();//抽象方法
}

class Pro extends Employee
{
	Pro(String name,String id,double pay)
	{
		super(name,id,pay);
	}

	public void work()//实现work方法
	{
		System.out.println("Pro work:");
		System.out.println("id:"+getId()+"\tname:"+getName()+"\tpay:"+getPay());
	}
}

class Manager extends Employee
{
	private int bonus;
    
	Manager(String name,String id,double pay,int bonus)
	{
		super(name,id,pay);
		this.bonus=bonus;
	}
	public int getBonus(){return bonus;}

	public void work()//实现work方法
	{
		System.out.println("manager work:");
		System.out.println("id:"+getId()+"\tname:"+getName()+"\tpay:"+getPay()+"\tbonus:"+getBonus());

	}


}

class AbstractDemo 
{
	public static void main(String[] args) 
	{
		Pro p=new Pro("张三","001",5000);
		Manager m=new Manager("李四","002",6000,5000);
		p.work();
		m.work();
	}
}

*/


/*25.
在一个类中编写一个方法,这个方法搜索一个字符串数组中是否存在某个字符,
如果存在,则返回这个字符在字符数组中第一次出现的位置(序号从0开始计算),
否则,返回-1。要搜索的字符数组和字符都以参数形式传递给该方法,如果传入的
数组为null,应抛出IllegalArgumentException异常。
在类的main方法中以各种可能出现的情况测试验证该方法编写得是否正确,
例如,字符不存在,字符存在,传入的数组为null等。



public int getIndex(char[] arr,char key)
{
	if(arr==null)
		throw new IllegalArgumentException("数组为空");
	for(int i=0;icir.radius)?this:cir;
	}
}
class TC
{
	public static void main(String[] args)
	{
		Circle cirl=new Circle(1.0);
		Circle cir2=new Circle(2.0);
		Circle cir;
		cir=cir1.compare(cir2);
		if(cir1==cir)
			System.out.println("圆1的半径比较大");
		else
			System.out.println("圆2的半径比较大");


	}
}

*/


七、面向对象(包package

1.对类文件进行分类管理。

2.给类提供多层命名空间。

3.写在程序文件的第一行。

4.类名的全称:包名.类名。

5.包也是一种封装形式。

/*
示例:包
*/
package pack; //包名:pack

class PackageDemo 
{
	public static void main(String[] args) 
	{
		System.out.println("Hello package!");
	}
}


1.在cmd下锁定当前文件目录后,输入javac -d . PackageDemo.java 进行编译,打包

2.输入java pack.PackageDemo 运行程序

说明:-d  :目录

      .   :代表当前目录。当然也可以指定打包的目录,例如:

javac -d c:\myclass PackageDemo.java 

运行时,可以先指定CLASSPATH路径,方便运行。例如:set CLASSPATH=c:\myclass

注意:是包的父目录。

八、面向对象(包与包之间访问)

总结:

1.包与包之间访问,被访问的包中的类以及类中的成员需要public修饰。

2.不同包中的子类可以直接访问父类中被protected权限修饰的成员。

包与包之间只可以使用两种权限:public          protected

  public  protected  default  private
同一个类中 yes yes yes yes
同一个包中 yes yes yes  no
子类     yes yes  no  no
不同包中  yes  no  no  no

 

注意:一个*.java文件中只能有一个public

/*
DemoA.java
*/
package packa;
public class DemoA extends packb.DemoB
{
	public void show()
	{
		System.out.println("DemoA show");
		method();
	}
}



/*
DemoB.java
*/
package packb;
public class DemoB 
{
	protected void method()//保护权限
	{
		System.out.println("DemoB method run");
	}
}


/*
DemoC.java
*/
package packb;
public class DemoC 
{
	protected void method()
	{
		System.out.println("DemoC method run");
	}
}


/*
PackageDemo.java
*/
package pack; //包名:pack

class PackageDemo 
{
	public static void main(String[] args) 
	{
		packa.DemoA d=new packa.DemoA();
		d.show();
	}
}
/*

PackageDemo.java:7: 错误: 找不到符号
                DemoA d=new DemoA();
                ^
  符号:   类 DemoA
  位置: 类 PackageDemo
PackageDemo.java:7: 错误: 找不到符号
                DemoA d=new DemoA();
                            ^
  符号:   类 DemoA
  位置: 类 PackageDemo
2 个错误


错误原因:类名写错。
类名全名:包名.类名

----------------------------------------------------

PackageDemo.java:7: 错误: 程序包packa不存在
                packa.DemoA d=new packa.DemoA();
                     ^
PackageDemo.java:7: 错误: 程序包packa不存在
                packa.DemoA d=new packa.DemoA();
                                       ^
2 个错误


错误原因:packa包不在当前目录下
需要set CALSSPATH=D:\java\myclass

----------------------------------------------------
PackageDemo.java:7: 错误: DemoA在packa中不是公共的; 无法从外部程序包中对其进行访
问
                packa.DemoA d=new packa.DemoA();
                     ^
PackageDemo.java:7: 错误: DemoA在packa中不是公共的; 无法从外部程序包中对其进行访
问
                packa.DemoA d=new packa.DemoA();
                                       ^
2 个错误

权限问题:将DemoA的权限设为public
因为有了包,范围变大,一个包中的类要被访问,必须要有足够大的权限
----------------------------------------------------

PackageDemo.java:8: 错误: show()在DemoA中不是公共的; 无法从外部程序包中对其进行
访问
                d.show();
                 ^
1 个错误

错误原因:类公有后,被访问的成员也要共有才可以被访问。
将show的权限设为public。
----------------------------------------------------


*/


九、面向对象(导入import

为了简化类名的书写,就是用一个关键字import

例如:

import packb.DemoC;//导入packb包的DemoC

import packb.*;//导入packb包的所有类,但不包含子包。

建议不要写通配符*。需要用到包中的哪个类,就导入哪个类。

当导入不同包的同名类时,定义对象时,类必须加包名。

建议定义包名不要重复,可以使用url完成定义,因为url是唯一的。

例如:

www.itcast.cn

package cn.itcast.demo

package cn.itcast.test

十、面向对象(jar包)

Java的压缩包。

1.方便项目的携带。

2.方便于使用,只需要在CALSSPATH设置jar路径即可。

3.数据库驱动,SSH框架等都是以jar包体现的。

/*
DemoA.java
*/
package packa;
public class DemoA 
{
	public void show()
	{
		System.out.println("DemoA show");
		
	}
}


/*
JarDemo.java
*/
package pack;
import packa.*;
class JarDemo 
{
	public static void main(String[] args) 
	{
		DemoA a=new DemoA();
		a.show();
		System.out.println("Hello jar pack!");
	}
}


执行过程:

C:\Users\Tomato>d:

D:\>cd java

D:\java>set classpath=d:\java\myclass

D:\java>javac -d d:\java\myclass DemoA.java

D:\java>javac -d d:\java\myclass JarDemo.java

D:\java>cd myclass

D:\java\myclass>jar -cf test.jar pack packa

D:\java\myclass>set classpath=d:\java\myclass\test.jar

D:\java\myclass>java pack.JarDemo

DemoA show

Hello jar pack!

提示:有关jar参数,在cmd下输入jar即可显示帮助。

技巧:

数据重定向:jar -tf test.jar >d:\show.txt

cmd显示的test.jar 中的目录当中的内容直接保存成D盘下的show.txt文件中。


你可能感兴趣的:(Java基础特性)