首页 > 代码库 > Java继承,多态,组合应用

Java继承,多态,组合应用

 
 继承:
  面向对象的三大特征之一:
  
  是类和类之间的一种拓展关系,是一种从一般到特殊的关系;
  
  格式: sub   extends Super,  我们把sub称为子类或者拓展类, 把super称为父类或者基类(超类)
  
 泛化: 把子类中的共性抽取到父类的过程;
 特化: 子类在父类的基础之上,拓展自己特有的状态和特征;
  
  Object: 是所有类的直接父类后间接父类;
  
  
  class  Student{} 等价于  class  Student extends Object{}
  
  直接父类:  直接继承的父类,有且只有一个,也就是说Java只支持单继承;
  间接父类: 直接父类或间接的父类的父类;
  
 方法和字段:
  private 修饰的成员不能被继承;
  默认访问权限的成员能不能被继承?  要是在同一个包中就能被继承
  protected 修饰的成员,可以被继承;
  public 修饰的成员,可以被继承;
  
  构造方法能不能被继承? 不能
  
  class Person{
   
   public Person(){}
  }
  
  class Student extends Person
  {
   //public Person(){}//ERROR
  }
  
  若父类所有的构造方法是用 private 修饰,不能有子类;
  
 
 子类实例化:
  子类初始化,会先默认调用父类的一个无参的构造方法,自己再初始化;
  
  子类的构造方法里,有一个隐式的 super();
  
  若我们显示的让子类去调用父类有参数的构造方法,默认的隐式的构造方法就不会被调用了;
  
  子类对象创建之前,必须有一个父类对象;
  
  
 方法覆写:
   当父类的某一个方法不适合子类对象的时候,就应当重新修改方法体;
   
  遵循的原则:  一同 两小 一大:
  
  一同: 方法签名相同
  两小: 
   1.返回值类型可以是父类返回值类型的子类或相同;
    父类的:Object show(){
     return null;
    }
    
    子类的:  String show()
    {
     return null;
    }
   2.异常更小
  一大: 子类方法的访问权限 >= 父类方法的访问权限
    父类的: private Object show(){
     return null;
    }
    
    子类的:  String show()
    {
     return null;
    }
  
   上面这个不是覆写:因为私有成员不能被继承
  
 必杀技:  若子类方法是覆写方法的话,  那么在方法上加上 @Override  是可以编译通过的;
 
  静态方法能不能被覆写: 不能!
   
   方法的覆写:属于多态,而多态是基于对象的(父类的一个变量指向子类的一个对象);
   
   而静态方法不属于对象,属于类;
 
 super:
  用在子类.,
  super:表示父类对象
  用于调用父类的方法或字段,用法和this一模一样
  
  调用父类的构造方法:
  
  super(参数);和this(参数);
  都表示在构造方法里调用构造方法;都必须写在构造方法的第一行
  
  不同:  this(参数),调用的当前类里面的构造方法,super(参数),调用的是直接父类里构造方法
   
 多态:
 
  面向对象的三大特征之一:
  
  Person  p = new Student();
  
  p的真正类型是学生;当是我们只把他当一般人看待;
  
  编译类型: 申明变量的类型  Person ,  是我们把它当做什么
  运行类型: 创建对象的类型  Student ,  是对象真正的类型
  
  多态的产生前提:继承
  当编译类型和运行类型不一致的时候,就会产生多态;
  
  多态定义:  同一个实体有多种形态;
  
  多态的作用: 可以屏蔽不同子类对象之间的差异,从而能写出更加通用的代码,能提高效率,维护性;
  
 引用类型转换:
  
  向上转型:  小->大, 自动转换, 这里说的小和大,说的是 继承关系中的子类和父类.
    
   可以把子类对象赋给父类变量;
   Person  p = new Student();
   
   Object类是所有类的父类.那么Object类型的变量能不能接受一切值? 可以!
  
   
  向下转型: 大 -> 小
  
   父类对象强制转换成子类对象;
   
   Student  s = (Student)p;
   
   一般的,再强转之前,要先判断该对象时候属于这个类类型;
    boolean b = 对象 instanceof 类
    
    对象的类型和类必须有继承关系;
   
   先判断 p是否是学生类型: 
   
   if(p instanceof Student)
   {
    Student  s = (Student)p;
   }
   
 多态方法调用:
  
  
  1.调用的方法不是覆写方法,子类有,父类没有;
   
  2.调用的方法是覆写的方法,父类有,子类也有;
  
  class Dog
  {
   public void eat()
   {
    System.out.println("0001");
   }
  }

  class Hasiqi extends Dog
  {
   public void eat()
   {
    System.out.println("0002");
   }
  }

  class ZangDog extends Dog
  {
   public void eat()
   {
    System.out.println("0003");
   }
  }

  class Zoo
  {
   public void feed(Dog d)
   {
    d.eat();
   }
  }

  class  DogDemo
  {
   public static void main(String[] args)
   {
    Zoo zoo=new Zoo();
    Hasiqi xiaoha=new Hasiqi();
    zoo.feed(xiaoha);

    ZangDog zd=new ZangDog();
    zoo.feed(zd);
   }
  }
 
 组合:
   extends  继承是一种从一般到特殊的关系,  也就是说 子类是父类的一种特殊情况;
  
   子类 is  父类的一种  is  A 关系
   
  组合,包含:  比如手机和手机卡,  手机里有手机卡 ,has  A关系
  
  class Card
  {
   private String num;//卡号

   public String getNum()
   {
    return num;
   }

   public void setNum(String num)
   {
    this.num=num;
   }

   public Card(String num)
   {
    this.num=num;
   }
  }


  //手机
  class CellPhone
  {
   private Card c;//卡是手机所包含的

   public CellPhone(Card c)
   {
    this.c=c;
   }

   public void connectied(String num) //联系
   {
    System.out.println(c.getNum()+"正在给"+num);
   }
  }

  //人
  class Person
  {
   public void call(CellPhone c,String num)
   {
    c.connectied(num);
   }
  }

  class PhoneDemo
  {
   public static void main(String[] args)
   {
    Person lucy=new Person();
    Person will=new Person();
    Card c=new Card("18720076967");

    CellPhone iphone=new CellPhone(c);
    lucy.call(iphone,"10086");
   }
  }