zoukankan      html  css  js  c++  java
  • 《Java基础学习笔记》JAVA面向对象之继承

    一、继承

    缺点: 打破了封装性,此时为了保证封装性使用 final关键字禁止从此类继承。

    1,提高了代码的复用性。
    2,让类与类之间产生了关系,有了这个关系,才有了多态的特性。

    注意:千万不要为了获取其他类的功能,简化代码而继承。      
            必须是类与类之间有所属关系才可以继承,所属系 is a.

    class Person
    {
        String name;
        int age;
    }
    
    class Student extends Person
    {
        void Speak()
        {
            System.out.println("学生-->姓名:"+name+",年龄:"+age);
        }
    }
    
    class Worker extends Person
    {
        void Speak()
        {
            System.out.println("工人-->姓名:"+name+",年龄:"+age);
        }
    }

    父子类出现后,类成员的特点:

    类中成员:
    1,变量    
        如果子类中出现非私有的同名成员变量时,子类要访问本类中的变量使用this,子类要访问父类中的同名变量使用super。   
        super的使用与this的使用几乎一致。   
        this代表的是本类对象的引用。   
        super代表的是父类对象的引用。

    2,函数   
        当子类出现和父类一模一样的函数时,当子类对象调用该函数,会运行子类函数内容。   
        如同父类的函数被覆盖一样(重写)。      
        当子类继承父类,沿袭了父类的功能,到子类中,但是子类虽具备该功能,但是功能的内容却和父类不一致,这时,没有必要定义新功能,而是使用覆盖    保留父类的功能定义,并重写功能内容。

    覆盖:    
    a)子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败。   
    b)静态只能覆盖静态。

    3,构造函数   
        在对子类对象进行初始化时,父类的构造函数也会运行,   
        那是因为子类的构造函数默认第一行有一条隐匿的语句 super();   
        super():会访问父类中空参数的构造函数。
        而且子类中所有的构造函数默认第一行都是 super()

       为什么子类一定要访问父类中的构造函数?

       因为父类中的数据子类可以直接获取。所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的。   
       所以子类在对象初始化时,要先访问一下父类中的构造函数。   
       如果要访问父类中指定的构造函数,可以通过手动定义super语句的方式来指定。

       注意:super语句一定定义在子类构造函数的第一行。

       结论(子类的实例化过程):   
       子类的所有的构造函数,默认都会访问父类中空参数的构造函数,因为子类每一个构造函数内的第一行都有一句隐式的super();    
       当父类中没有空参数的构造函数时,子类必须手动通过supert或者this语句形式来指定要访问的构造函数。       

        当然:   
        子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数。   
        子类中至少会有一个构造函数会访问父类中的构造函数。

       为什么this()和super()不能同时出现在构造函数中?   
       答:因为this()和super()都必须在第一行。

       为什么this()和super()必须在第一行?   
       答:因为初始化动作要先做。

  • 相关阅读:
    服务器状态码
    QuerySet中添加Extra进行SQL查询
    django配置一个网站建设
    MySQL数据库查询中的特殊命令
    125. Valid Palindrome
    121. Best Time to Buy and Sell Stock
    117. Populating Next Right Pointers in Each Node II
    98. Validate Binary Search Tree
    91. Decode Ways
    90. Subsets II
  • 原文地址:https://www.cnblogs.com/cxmsky/p/2845767.html
Copyright © 2011-2022 走看看