继承

java不支持多继承就是因为方法体不同会导致调用的不确定性,只要解决了这个问题,那就可以。因此接口是可以多继承的


继承的好处:

1.提高了代码的复用性

2.让类与类之间产生了关系,给第三个特征多态提供了前提


继承的弊端: 打破了封装性

java中支持单继承,不直接支持多继承,但对c++中的多继承机制进行了改良

 单继承: 一个子类只能有一个父类。

多继承:一个子类可以有多个直接父类(java中不允许,因为多个父类中有相同成员时会产生调用的不确定性,进行了改良)

                 在java中是通过“多实现”的方式来体现。


 java支持多层(多重)继承      

      C继承B,B继承A

    就会出现继承体系

当要使用一个继承体系时:

1.查看该体系中的顶层类,了解该体系的基本功能

2.创建体系中的的最子类对象,完成功能的使用  


什么时候定义继承呢?

当类与类之间存在着所属关系的时候,就定义继承。xxx是yyy中的一种,xxx  extends  yyy

所属关系: is  a 关系


在子父类中,成员的特点体现

1.成员变量

          当本类的成员和局部变量同名用this区分

           当子父类中的成员变量同名用super区分父类

  this和super的用法很相似

        this:代表一个本类对象的引用

        super:代表一个父类的空间

2.成员函数

        当子父类中出现成员函数一模一样的情况,会运行子类的函数

         这种现象,称为覆盖操作,这是函数在子父类中的特性

      函数的两个特性:

                  1.重载:同一个类中

                   2.覆盖:子类中,覆盖也称为重写,覆写     override

   覆盖的注意事项:

    1.子类方法覆盖父类方法时,子类权限必须要大于等于父类的权限

     2.静态只能覆盖静态,或被静态覆盖   ,必须都为静态或都不是   

什么时候使用覆盖操作?

   当对一个类进行子类的扩展时,子类需要保留父类的功能声明

   但是要定义子类中该功能的特有内容时,就是用覆盖操作完成

3.构造函数

     在子类构造对象时,发现访问子类构造函数时,父类也运行了

    为什么呢?

      原因是:在子类的构造函数中第一行有一个默认的隐式语句。super();调用的就是父类中的空参数的构造函数


子类的实例化过程,子类中所有的构造函数默认都会访问父类中的空参数的构造函数


为什么子类实例化的时候要访问父类的构造函数呢?

那是因为子类继承了父类,获取到了父类中内容(属性),所以在使用父类内容之前,要先看父类是如何

对自己的内容进行初始化的

所以子类在构造对象时,必须访问父类中的构造函数,为了完成这个必要的动作,就在子类的构造函数中加入了super() 语句。


如果父类中没有定义空参数构造方法,那么子类的构造函数必须用super()明确要调用父类中哪个构造函数

同时子类构造函数中如果使用this调用了本类构造函数,那么super就没有了,因为super和this都只能定义在第一行,所以只能有一个。

但是可以保证的是,子类中肯定会有其他的构造函数访问父类的构造函数

注意:super语句必须要定义子啊子类构造函数的第一行,因为父类的初始化动作要先完成




通过super初始化父类内容时,子类的成员变量并未显示初始化,等super()父类初始化完毕后,才进行子类的成员变量显示初始化


一个对象实例化过程:

Person  p = new Person()

1.jvm会读取指定的路径下的person.class文件,并加载进内存,

         并会先加载person的父类(如果有直接的父类的情况下)

2.堆内存中开辟空间,分配地址

3.并在对象空间中,对对象中的属性进行默认初始化

4.调用对应的构造函数,进行初始化

5.在构造函数中,第一行会先到调用弗雷中构造函数进行初始化

6.父类初始化完毕后,再对子类的属性进行显示初始化

7.再进行子类构造函数的特定初始化

8.初始化完毕后,将地址值赋值给引用变量


class Father{  
    static{  
          
        System.out.println("静态FU");  
    }  
    {  
        System.out.println("构造代码FU");  
    }  
    public Father(){  
        System.out.println("构造方法FU");  
    }  
}  
class Zi extends Father{  
    static{  
          
        System.out.println("静态ZI");  
    }  
    {  
        System.out.println("构造代码ZI");  
    }  
    public Zi(){  
        System.out.println("构造方法ZI");  
    }  
}  
class Test{  
    public static void main(String[] args){  
        Zi z=new Zi();  
          
    }  
}

/*
结果是:静态FU,静态ZI,构造代码FU,构造方法FU,构造代码ZI,构造方法ZI

*/


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值