day09【继承、super、this、抽象类】

  • 如果子父类中出现了同名的成员变量时,在子类中需要访问父类中非私有成员变量时,需要使用 super 关键字,修饰父类成员变量,类似于之前学过的 this 。
  • 如果子类父类中出现重名的成员方法,这时的访问是一种特殊情况,叫做方法重写 (Override)。用surper.父类成员方法,表示调用父类的成员方法。

super用法

  1. 子父类中出现了同名的成员变量时,在子类中需要访问父类中非私有成员变量时,需要使用 super 关键字,修饰父类成员变量,类似于之前学过的 this 。
class father{
int num=5;
}
class son extends father{
int num=6;
public void show() {
// 访问父类中的num
System.out.println("Fu num=" + num);
// 访问子类中的num
System.out.println("Zi num=" + num);
}
} 
class ExtendsDemo03 {
public static void main(String[] args) {
// 创建子类对象
Zi z = new Zi();
// 调用子类中的show方法
z.show();
}
} 演
示结果:
Fu num = 6
Zi num = 6
}

应该用:surper.父类成员变量名
小贴士:Fu 类中的成员变量是非私有的,子类中可以直接访问。若Fu 类中的成员变量私有了,子类是不能
直接访问的。通常编码时,我们遵循封装的原则,使用private修饰成员变量,那么如何访问父类的私有成员
变量呢?对!可以在父类中提供公共的getXxx方法和setXxx方法。

class Zi extends Fu {
// Zi中的成员变量
int num = 6;
public void show() {
//访问父类中的num
System.out.println("Fu num=" + super.num);
//访问子类中的num
System.out.println("Zi num=" + this.num);
}
} 演
示结果:
Fu num = 5
Zi num = 6

继承后的特点——构造方法

当类之间产生了关系,其中各类中的构造方法,又产生了哪些影响呢?
首先我们要回忆两个事情,构造方法的定义格式和作用。

  1. 构造方法的名字是与类名一致的。所以子类是无法继承父类构造方法的。
  2. 构造方法的作用是初始化成员变量的。所以子类的初始化过程中,必须先执行父类的初始化动作。子类的构造方法中默认有一个 super() ,表示调用父类的构造方法,父类成员变量初始化后,才可以给子类使用。代码如下:
class Fu {
private int n;
Fu(){
System.out.println("Fu()");
}
}
class Zi extends Fu {
Zi(){
// super(),调用父类构造方法
super();
System.out.println("Zi()");
}
} 
public class ExtendsDemo07{
public static void main (String args[]){
Zi zi = new Zi();
}
} 
输出结果:
Fu()
Zi()

super和this的含义:

super :代表父类的存储空间标识(可以理解为父亲的引用)。
this :代表当前对象的引用(谁调用就代表谁)。
super和this的用法

  1. 访问成员
    this.成员变量 ‐‐ 本类的
    super.成员变量 ‐‐ 父类的
    this.成员方法名() ‐‐ 本类的
    super.成员方法名() ‐‐ 父类的
class Animal {
public void eat() {
System.out.println("animal : eat");
}
} c
lass Cat extends Animal {
public void eat() {
System.out.println("cat : eat");
} p
ublic void eatTest() {
this.eat(); // this 调用本类的方法
super.eat(); // super 调用父类的方法
}
} p
ublic class ExtendsDemo08 {
public static void main(String[] args) {
Animal a = new Animal();
a.eat();
Cat c = new Cat();
c.eatTest();
}
} 输
出结果为:
animal : eat
cat : eat
animal : eat
  1. 访问构造方法
    this(…) ‐‐ 本类的构造方法
    super(…) ‐‐ 父类的构造方法
    子类的每个构造方法中均有默认的super(),调用父类的空参构造。手动调用父类构造会覆盖默认的super()。super() 和 this() 都必须是在构造方法的第一行,所以不能同时出现。
package 高级语法.Day11.Day11;
        class Animal {
            Animal(){
                System.out.println("我是父类的无参构造函数");
            }
            Animal(int a){
                System.out.println("我是父类的带一个参数的构造函数");
            }
        }
        class Cat extends Animal {
            Cat(){
                super(1);
                System.out.println("我是子类呀");
            }
            public void eat() {
                System.out.println("cat : eat");
            }

        }
        public class superandthis {
            public static void main(String[] args) {
                Cat c = new Cat();
            }
        }
        //结果:我是父类的带一个参数的构造函数
		//我是子类呀



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值