黑马程序员_Java基础_面向对象(六)_10

                                       ------- android培训java培训、期待与您交流! ----------
 

导读:处理语句其他格式,异常覆盖时异常的特点,练习(圆长取面积),异常总结,总练习题,包package,包与包之间访问,导入importjar包。
 

1、异常-处理语句其他格式

l  第一个格式:

try{        }catch (){     }

l  第二个格式:

try{}catch (){      }finally{       }

l  第三个格式:

try{        }finally{       }

l  //记住一点:catch是用于处理异常。如果没有catch就代表异常没有被处理过,如果该异常是检测时异常,那么必须声明。

class Demo

{

       public void method()

       {

              try

              {

                     throw new Exception(); //放在try-catch中将问题从内部解决,才能编译通过。不写在try-catch中时,因为没有声明,编译不能通过。(问题被解决可以不声明,问题没有解决,必须要声明出去。什么叫问题解决?有catch就叫问题解决)

              }

              finally   //这样编译也不能通过,因为没有catch就是没有处理,要标识出去。tryfinally是可以在一起的,finally中是要关的资源或者一定要执行的代码。

              {

                     //关资源。(产不产生问题我不管,但资源要先关掉)

              }

       }

}

class 

{

       public static void main(String[] args)

       {

              System.out.println("HelloWorld!");

       }

}    

 

try

{

       Throw new Exception();

}

catch(Exceptione)  //这时编译还是失败的,因为你抓了一个异常后,你又抛出去一个

{    

       try  //catch中还可以写try-catch

       {

              throw e;

       }

catch()

{

}

}

 

2、异常-覆盖时的异常特点

l  异常要声明的话,要声明在函数上。异常有一个特性叫做覆盖。

l  异常在子父类覆盖中的体现;

Ø  子类在覆盖父类时,如果父类的方法抛出异常,那么子类的覆盖方法,只能抛出父类的异常或者该异常的子类。(或者不抛)(这是java中的一个规律)

Exception

       |--AException

              |--BException

       |--CException

父类抛Aexceptoin,子类可以抛AException或者BExceptoin。这样多态时,才可以对异常进行处理。如果子类中真有的CException,你只能内部处理(try),不能抛(throws)

Ø  如果父类方法抛出多个异常,那么子类在覆盖该方法时,只能抛出父类异常的子集(父类异常或其子异常中选几个)。(如果自己都处理的话,就不用再抛了)

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

 

3、练习:

/*

有一个圆形和长方形。都可以获取面积。对于面积如果出现非法的数值,视为是获取面积出现问题。问题通过异常来表示。现有对这个程序进行基本设计。

*/

class NoValueException extends RuntimeException //程序错误就停掉。为什么要用自定义类呢?一、自定义类中可以定义程序特有的内容。二、RuntimeException和程序的名称有关系吗?看到RuntimeException不能明确的知道这个Runtime代表的是哪一类的异常。所以我们起了一个特有名称知道发生了什么问题。这叫做对问题名称的描述。

{

       NoValueException(Stringmessage)

       {

              super(message);

       }

}

interface Shape

{

       void getArea();

}

class Rec implements Shape

{

       private int len,wid;

       Rec(int len ,intwid)//throws NoValueException  在这里也不再标识了

       {

              if(len<=0 ||wid<=0)

                     throw newNoValueException("出现非法值");

              this.len = len;

              this.wid = wid;

       }

       public void getArea()

       {

              System.out.println(len*wid);

       }

}

class Circle implements Shape

{

       private int radius;

       public static final doublePI = 3.14;

       Circle(int radius)

       {

              if(radius<=0)

                     throw newNoValueException("非法");

              this.radius =radius;

       }

       public void getArea()

       {

              System.out.println(radius*radius*PI);

       }

}

class  ExceptionTest1

{

       public static voidmain(String[] args)

       {    

              Rec r = newRec(3,4);

              r.getArea();

              Circle c = newCircle(-8);

              System.out.println("over");

       }

}

 

//学完异常后,不要这么干了。结果会输出0无意义。应该是什么样呢?Rec r = new Rec(-3,4);你传的值都是错的,长方形不存在,你怎么能调用面积,不应该有输出结果。

Iflen<=0 || wid<=0   

       System.out.println(“错了”)

else

{

       this.len = len;

       this.wid = wid;

}

正常流程代码和问题处理代码,结合非常紧密,阅读性比较差。

我们只保留正常问题代码,当问题发生时,我们到问题发生的位置上再去看处理代码就很方便。异常的出现,可以合正常流程代码和问题代码相分离。如果你要抛出throws这个问题的话,说明这个问题是可处理的,处理完所,catch中会给出相应的处理方式,那么你会发现正常流程代码和问题处理代码分离开了。

异常是java中非常重要的机制,以后写代码中会经常出现问题,遇到问题怎么办,全用异常描述,来进行封装对象。问题也是一个对象。

 

4、异常总结

l  异常:

是什么?是对问题的描述。将问题进行对象的封装。

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

l  异常体系:

    Throwable

           |--Error

           |--Exception

                  |--RuntimeException

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

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

l  throwthrows的用法:

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

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

 

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

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

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

l  如果函数声明了异常,调用者需要进行处理。处理方法可以throws可以try

异常有两种:

       编译时被检测异常

              该异常在编译时,如果没有处理(没有抛也没有try),编译失败。

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

       运行时异常(编译时不检测)

              在编译时,不需要处理,编译器不检查。

              该异常的发生,建议不处理,让程序停止。需要对代码进行修正。

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

l  异常处理语句:

try

{

       需要被检测的代码;

}

catch ()

{

       处理异常的代码;

}

finally

{

       一定会执行的代码;

}

 

有三个结合格式:

1.    try

       {

             

       }

       catch ()

       {

       }

2.    try

       {

             

       }

       finally

       {

      

       }

3.    try

       {

             

       }

       catch ()

       {

       }

       finally

       {

      

       }

注意:

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

2finally只有一种情况不会执行。当执行到System.exit(0);fianlly不会执行。

System.exit(0); //系统中有一个静态的方法,系统退出的意思。JVM结束

 

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

l  自定义异常:

       定义类继承Exception或者RuntimeException

       1,为了让该自定义类具备可抛性。

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

 

       当要定义自定义异常的信息时,可以使用父类已经定义好的功能。

       异常异常信息传递给父类的构造函数。

       class MyException extendsException

       {

              MyException(Stringmessage)

              {

                     super(message);

              }

       }

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

 

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

l  异常的好处:

       1,将问题进行封装。

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

 

l  异常的处理原则:

       1,处理方式有两种:try 或者 throws

       2,调用到抛出异常的功能时,抛出几个,就处理几个。一个try对应多个catch

       3,多个catch,父类的catch放到最下面。

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

              也不要不写。

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

              try

              {

                     throw newAException();

              }

              catch (AException e)

              {

                     throw e;

              }

 

              如果该异常处理不了,但并不属于该功能出现的异常。

              可以将异常转换后,在抛出和该功能相关的异常。

 

              或者异常可以处理,当需要将异常产生的和本功能相关的问题提供出去,

              当调用者知道。并处理。也可以将捕获异常处理后,转换新的异常。

              try

              {

                     throw newAException();

              }

              catch (AException e)

              {

                     // AException处理。(处理完本层的异常,再把异常暴露给调用者)

                     throw newBException();

              }

 

        比如,汇款的例子。
 
       我汇钱给张三,他贴有问题,没有汇成功。处理,先把汇的100元先存到转帐的帐号中来,完了之后告诉转帐的人,没有汇款成功。

异常的注意事项:(重要

       在子父类覆盖时:

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

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

参阅

ExceptionTest.java 老师用电脑上课

ExceptionTest1.java 图形面积。

 

class 

{

       public static voidmain(String[] args)

       {

              int x = 0;

              try

              {

                     x = 4;

              }

              catch ()

              {

              }

              finally

              {

                     System.out.println("x="+x);

              }

       }

}

 

 

5、总练习:

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

1.写出程序结果

class Demo

{    

       public static voidfunc()//throws Exception

       {

              try

              {

                     throw  new Exception();

              }

              finally

              {

                     System.out.println("B");

              }

       }

       public static voidmain(String[] args)

       {

              try

              {

                     func();

                     System.out.println("A");

              }

              catch(Exception e)

              {

                     System.out.println("C");

              }

              System.out.println("D");

       }

}

编译失败:

如果func放上声明了该异常。结果是?B C D

 

===================================================================

2.写出程序结果

class Test

{

       Test()

       {

              System.out.println("Test");

       }

}

class Demo extends Test

{

       Demo()

       {

              //super();

              System.out.println("Demo");

       }

       public static voidmain(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 voidmain(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 voidmain(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 voidmain(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 voidmain(String[] args)

       {

              int i=4;

              Super d=newDemo("A");

              System.out.println(d.i);

       }

}

B C 5

 

 

===================================================================

7.

interface Inter

{

       void show(int a,int b);

       void func();

}

class Demo

{

       public static voidmain(String[] args)

       {

              //补足代码;调用两个函数,要求用匿名内部类

              Inter in = newInter()

              {

                     public voidshow(int a,int b)

                     {

                    

                     }

                     public voidfunc()

                     {

                    

                     }

              };

 

              in.show(4,5);

              in.func();

             

       }

}

 

 

===================================================================

8.

写出程序结果

class TD

{

       int y=6;

       class Inner

       {

              static int y=3; 

              void show()

              {

                     System.out.println(y);

              }

       }

}

class TC

{

       public static voidmain(String[] args)

       {

              TD.Inner ti=newTD().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 a,b;

       //private int sum;

       public void add(int a,intb)

       {

              this.a =a;

              this.b = b;

 

              //sum = a+b;

       }

       public void show()

       {

              System.out.println(a+b);

              //System.out.println(sum);

       }

 

}

class D

{

       public static voidmain(String[] args)

       {

              C c=new C();

              c.add(4,2);

              c.show();//通过该函数打印以上两个数的和。

       }

}

 

 

 

===================================================================

13.写出程序结果      //比较第十六题。

class Demo

{

       public static voidmain(String[] args)

       {

              try

              {

                     showExce();   //封装的异常方法,表示在编译的时候可能发生问题,也可能不发生问题,因此编译的时候下面的语句可以执行到。这里不同于直接写throw newException();写这名话的话,下面的语句一定执行不到。

                     System.out.println("A");

              }

              catch(Exception e)

              {

                     System.out.println("B");

              }

              finally

              {

                     System.out.println("C");

              }

              System.out.println("D");

       }

       public static voidshowExce()throws Exception  //将一个异常封装到一个方法中去。

       {

              throw newException();

       }

}

 

// 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 voidmain(String[] args)

       {

              Demo d=newDemo("yes");

              System.out.println(d.i);

       }

}

//编译失败,因为父类中缺少空参数的构造函数。

//或者子类应该通过super语句指定要调用的父类中的构造函数。

 

===================================================================

15.写出程序结果

class Super

{

       public int get(){return 4;}

}

class Demo15 extends Super

{

       public long get(){return5;}                  

       public static voidmain(String[] args)

       {

              Super s=newDemo15();

              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 voidmain(String[] args)

       {

              try

              {

                     func();

              }

              catch(Exception e)

              {

                     System.out.println("C");

              }

              System.out.println("D");

       }

}

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

记住:throw单独存在,下面不要定义语句,因为执行不到。

 

 

===================================================================

17.

class Demo

{    

       public void func()

       {

              //位置1

              new  Inner();

             

       }

       class Inner{}

       public static voidmain(String[] args)

       {

              Demo d=new Demo();

              // 位置2

              new Inner();//不可以,因为主函数是静态的。如果访问inner需要被static修饰。

       }

}

 

A.在位置1 new Inner();//ok

B.在位置2 new Inner();          

C.在位置2 new d.Inner();//错误,格式错误。 new newDemo().Inner();

D.在位置2 new Demo.Inner();//错误,因为inner不是静态的。

 

===================================================================

18.

写出程序结果

class Exc0 extends Exception{}

class Exc1 extends Exc0{}

 

class Demo

{

       public static voidmain(String[] args)

       {

              try

              {

                     throw newExc1();

              }           

              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 voidmain(String[] args)

       {

              //补足代码;(匿名内部类)

             

              new Demo().show(newTest()  //不写new Demo()编译也是失败的,show()不是静态的。

              {

                     public voidfunc(){}

              });

             

       }

       void show(Test t)

       {

              t.func();

       }

}

 

===================================================================

20.写出程序结果     

class Test

{

       public static Stringoutput="";

       public static void foo(inti)

       {

              try

              {

                     if(i==1)

                            thrownew Exception();  

                     output+="1";

              }

              catch(Exception e)

              {

                     output+="2";

                     return;

              }

              finally

              {

                     output+="3";

              }

              output+="4";

       }

       public static voidmain(String args[])

       {

              foo(0);

              System.out.println(output);//134

              foo(1);

              System.out.println(output);//13423

       }

}

 

===================================================================

21.

建立一个图形接口,声明一个面积函数。圆形和矩形都实现这个接口,并得出两个图形的面积。

注:体现面向对象的特征,对数值进行判断。用异常处理。不合法的数值要出现“这个数值是非法的”提示,不再进行运算。

 

===================================================================

22.

补足compare函数内的代码,不许添加其他函数。

class Circle

{

       private static doublepi=3.14;

       private double radius;

       public Circle(double r)

       {

              radius=r;

       }

       public static doublecompare(Circle[] cir)

       {

              //程序代码//其实就是在求数组中的最大值。

             

              int max = 0;//doublemax = cir[0].radius;

 

              for(int x=1;x<cir.length; x++)

              {

                     if(cir[x].radius>cir[max].radius)

                            max =x;

              }

 

              return cir[max].radius;

       }

}

class TC

{

       public static voidmain(String[] args)

       {

              Circle cir[]=newCircle[3];//创建了一个类类型数组。(这个数组中能装的是对象。类类型的数组,如果没有初始化的话,默认类型是null

              cir[0]=newCircle(1.0);  //对每个对象分别初始化。

              cir[1]=newCircle(2.0);

              cir[2]=newCircle(4.0);

              System.out.println("最大的半径值是:"+Circle.compare(cir));

       }

}

===================================================================

23.写出程序结果     

public class Demo

{    

       private static int j = 0;

       private static booleanmethodB(int k)

       {

              j += k;

              return true;

       }

       public static voidmethodA(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 个属性:

姓名、工号以及工资。经理也是员工,除了含有员工的属性外,另为还有一个

奖金属性。请使用继承的思想设计出员工类和经理类。要求类中提供必要的方

法进行属性访问。

 

 

==================================================================

25.

在一个类中编写一个方法,这个方法搜索一个字符数组中是否存在某个字符,

如果存在,则返回这个字符在字符数组中第一次出现的位置(序号从0开始计算),

否则,返回-1。要搜索的字符数组和字符都以参数形式传递传递给该方法,

如果传入的数组为null,应抛出IllegalArgumentException异常。

在类的main方法中以各种可能出现的情况测试验证该方法编写得是否正确,

例如,字符不存在,字符存在,传入的数组为null等。

getIndex(null,'a');

 

public int getIndex(char[] arr,char key)

{

       if(arr==null)

              throw newIllegalArgumentException("数组为null");

       for(int x=0;x<arr.length; x++)

       {

              if(arr[x]==key)

              return x;

       }

       return -1;

}

 

===================================================================

26.

补足compare函数内的代码,不许添加其他函数。

class Circle

{    

       private double radius;

       public Circle(double r)

       {

              radius=r;

       }

       public Circlecompare(Circle cir)

       {

              //程序代码

              /*

              if(this.radius>cir.radius)

                     return this;

              return cir;

              */

 

 

              return(this.radius>cir.radius)?this: cir;

             

       }

}

class TC

{

       public static voidmain(String[] args)

       {

              Circle cir1=newCircle(1.0);

              Circle cir2=newCircle(2.0);

              Circle cir;

              cir=cir1.compare(cir2);

              if(cir1==cir)

                     System.out.println("1的半径比较大");

              else

                     System.out.println("2的半径比较大");

       }

}

 

6、包package

Ø  对类文件进行分类管理。

Ø  给类提供多层命名空间。

Ø  写在程序文件的第一行。(用关键字package

Ø  类名的全称的是  包名.类名。(有了包之后,类的名称就变化了。编译时要做一件事情,那就是加参数:javac –d d:\javaPackage.java。目录太长了可以这样写:“点,空格,Package.java”,指定包所在的位置。运行:java pack.PackageDemo

Ø  包也是一种封装形式。

l  类文件产生以后,就会出现这样一个问题:当类的内容不一样,类的名称重复的时候会导致在一个文件夹下,只存在一个文件。文件夹在java中可以通过包来表示。

l  定义包名,所有的名称小写。

l  写项目的时候必须先写包,再写类。以前没有写是因为java把当前目录做为默认包存在。

l  包的出现可以让java的类的文件和源文件相分离。

 

5、包与包之间访问

l  不同包中的类要怎样访问呢?

当运行的多个类的文件,不是在一个源文件中放的时候,要先编译没有main的文件。

l  外部类的权限有两个:一个是外部权限,一个是默认权限。

l  包是封装,函数也是封装,而不仅仅是private是封装。

l  默认权限在相当于包的范围内也是隐藏的。

l  不同包中的类可不可以有关系呢?这是可能的。可以用packa中的类继承自packb中的类。

l  Java给不同包中的子类提供了一个特殊的权限(你认我为父,你就可能拿到一些别人拿不到的东西)。Protected,保护权限(只可能给子类使用)。

l  PackageDemo.java:8:找不到符号

符号:  DemoA

位置:  pack.PackageDemo

                DemoA d = new DemoA();

                ^

PackageDemo.java:8:找不到符号

符号:  DemoA

位置:  pack.PackageDemo

                DemoA d = new DemoA();

                              ^

错误

错误原因:类名写错。

因为类名的全名是:包名.类名

l  PackageDemo.java:8:软件包 packa 不存在

                packa.DemoA d = newpacka.DemoA();

                     ^

PackageDemo.java:8:软件包 packa 不存在

                packa.DemoA d = newpacka.DemoA();

                                         ^

错误

错误原因:packa包不在当前目录下

需要设置classpath,告诉jvm去哪里找指定的packa包。

l  PackageDemo.java:8:packa.DemoA  packa 中不是公共的;无法从外部软件包中对其进行访问

                packa.DemoA d = new packa.DemoA();

                     ^

PackageDemo.java:8:packa.DemoA  packa 中不是公共的;无法从外部软件包中对其进行访问

                packa.DemoA d = newpacka.DemoA();

                                         ^

错误

错误原因:有了包,范围变大,一个包中的类要被访问,必须要有足够大的权限。

所以被访问的类要被public修饰。

l  PackageDemo.java:9:show()  packa.DemoA 中不是公共的;无法从外部软件包中对其进行访问

                d.show();

                 ^

错误

错误原因:类公有后,被访问的成员也要公有才可以被访问。

l  总结:

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

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

l  包与包之间可以使用的权限只有两种,public  protected

l  四种权限:

                        public      protected       default     private

同一个类中           ok            ok               ok            ok

同一个包中           ok            ok               ok

子类                     ok             ok            

不同包中             ok

l  同一个包中protected的作用只限于覆盖。

public classDemoB

{

       protected void method()

       {

              System.out.println("demoBmethod run");

       }

}

class C extends DemoB

{

       protected void method() //如果默认则不能被覆写,但是protectedpublic可以被覆写。

       {

              System.out.println("demoCmethod run");

       }

}

l  类前面加了public后,类名必须要和java文件名保持一致(一个.java文件中不能出现两个或以上公有类或者接口。可以多个java文件放在同一个包中,都用public解决问题)

l  java.lang : java的核心包 jdk1.2版本以后,该包中的类自动导入。

java.awt: 用于制作图形界面。

java.io:inputoutput  用于操作设备上的数据。

java.util : 这里定义是java的工具类。集合,日期。

java.net:用于网络通讯的。

java.applet:  application let        server  let   servlet      java server page   jsp 

class hahaimplements Servlet

class heheextends HttpServlet

 

6、导入import

l  为了简化类名的书写,使用一个关键字,importimport 导入的是包中的类。(一个程序中不写import也是可以的,因为我可以按照全名来写)

l  例:importpackb.haha.hehe.heihei.*; //记着一个通配符“*”,表示将heihei目录中的所有的java类导入到我们所需要的目录中来。

l  建议,不要写通配符 * ,需要用到包中的哪个类,就导入哪个类。(在实际开发中不这么做,因为如果你这个文件夹中有十个类,那么这十个类都进来了,可是你只用到其中的一个类,比较占内存的空间)

l  在运用高级工具的时候,package是不用写的,import是没有人写的,全都是自动导入。快捷键:Ctrl+shift+o

l  c:\myclass

c:\myclass\packb\DemoA.class

c:\myclass\packb\haha\DemoZ.class

import packb.*;    //这是导入packb包中的类,但是它不能导入packb包中haha包中的java

importpackb.haha.*;

l  import packa.*;

import packb.*;

//如果有同名的类,编译器会搞不清楚这个类到底是谁的。导入不同包中的类出现重名的时候,这个类必须加包名,以区分开,否则这个类是不能运行的。

l  为什么写包名?除了管理之外,还有一点尽量避免类重名。

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

www.itcast.cn

package cn.itcast.demo

packagecn.itcast.test

 

7jar

l  Java中的压缩包要用一个工具来完成,叫做jar.exe

l  命令:jar –cf haha.jarpacka pack   //packapack文件夹中的内容打包到haha.jar文件中去

Ø  -c:创建一个文件

Ø  -f:起一个文件名字

l  命令:jar –tf haha //查看压缩包中的内容:

Ø  -t:列出归档目录

Ø  列出jar文件后,会有下面的语句:

Ø  META_INF/                 //这两个是jar包生成之后,自动生成的一个文件夹这个文件夹中存放了配置清单文件。其中的数据我们是可以改动的,改动完jar包会有一些特殊的意义,会有一些特殊的操作方式。

META_INF/MANIFEST.MF

Ø  也可用解压文件去查看——WinRAR(只要是压缩文件,解压文件都能看)

打压缩文件后,packapack文件的父目录不再是C:\myclass了,变成了haha.jar这个jar包。你把类都封装到java包中,这个类还能运行,只不过多了一层目录“haha.jar”

l  你想使用老师的这些工具的话,我们只需要把打包,并把jar包放在classpath文件路径下,那么java包中的数据,你都能用。我们在开发的时候,我们总能找到一些对象来完成,比较方便。去网上找,如Apache的网站上会有一些对java对象又进行封装的一些常用工具。只用把相关的包下载下来就可以了,这个包可能是ZIP包,解压缩后,这里面有一个jar包,还有一些这些类的说明文档。把jar包放在classpath路径下,并打开文档,查里面的工具就可以了。看工具的时候一般Copy代码,英文你看不懂,但代码你能看懂。

l  命令:jar –cvf a.jarpack packa  //显示出压缩的详细信息,压缩比等。

l  命令:jar –tvfa.jar   //显示出jar文件的详细信息,还带的有时间。

l  命令:jar –tf a.jar>c:\1.txt   //doc命令行的东西,把数据存到文件中去。文件重定向

l   命令:jar-xvf mypack.jar  //解压缩

l  命令:jar–cvfm  mypack.jar mf.txt  packa packb  //自定义jar包的清单文件

l  jre/lib中的rt.jarjava中的(运行时)类库,java面向对象都在这里呢。JDK中的libjava编译器的类库,其中有一个tools.jar,在tools.jar\com\sun\tools\javac\目录有一个Main.classjavac 是由所有的java文件组成的,由java写成的,但java程序由class组成,为了方便运用,它将class文件组成一个exe的包,方便应用。

l  Error严重错误,虚拟机报的,虚拟机在运行tools中的文件。为什么JDK中要有虚拟机?因为JDK中全是编译工具,编译工具是类写的,类要虚拟机去运行。所以在JDK中必须要有一个jre运行时的环境。

l  JDKsrc.zip文件是java中所有类的源文件。Linux开源,所以安全,你发现一个漏洞给补上了,我发现一个又给补上了。Object.java中一个关键字,native,本地注册,调用系统的东西。有5个内存区域栈,堆,方法区,寄存器,本地方法区,存的就是native的相关东西。本地方法区中存的都是底层的东西,我们看不着,也不会让你看的,太危险。 

                                      ------- android培训java培训、期待与您交流! ----------  



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值