java的继承机制有什么好处_JAVA基础-继承机制

需要掌握的知识点:

包的使用

继承时,子类如何覆盖父类方法(重写和重载)

继承时,构造方法的执行过程

JVM中子类如何实例化(先实例化父,再实例化子)

super和this关键字

final关键字

包的导入

import java.util.Scanner;

public class PackageTest {

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

sc.nextInt();

}

}

Object类是所有类的鼻祖

当没有任何显示的继承类时,默认继承java.lang包下的Object类

//object源码中一些比较常用的方法

public boolean equals(Object obj) { //引用比较

return (this == obj);

}

//返回类名加hashcode

public String toString() {

return getClass().getName() + "@" + Integer.toHexString(hashCode());

}

public final native Class> getClass(); //返回类名

访问修饰符权限

访问修饰符

同类

同包

子类

其他

public

protected

默认

private

其中protected含义是保护继承的子类,这样在不同的包中就可以让子类访问了。

使用super关键字,super代表父类对象

访问父类构造方法

super();

super(name);

访问父类属性

super.age;

super.name;

访问父类方法

super.print();

总结一下super和this 的区别

----

----

----

----

this访问本类构造方法必须第一行

本类属性

本类方法

this可以引用当前对象

super访问父类构造方法必须第一行

父类属性

父类方法

super只能出现在子类中

方法重写

子类方法必须和父类具有相同的方法名称、参数列表和返回值类型(Eclipse中快捷键ALT+/可以快速重构父类函数)

子类方法的访问权限只能大于等于父类

子类方法抛出的异常不能大于父类被重写的异常

对象的创建过程

JVM会先加载父类,再加载子类

在栈内存中为定义的变量分配内存空间,同时在堆内存中为真正的对象分配内存空间

调用构造器来为创建出的对象进行初始化

子类中所有的构造方法,默认都会先调用父类中无参的构造方法 (如果父类中没有无参的构造方法,那么在子类中要利用super手动添加一个父类的有参构造方法)

Object类的构造器是最先被执行的

final 关键字

final修饰类表示该类不能被继承

比如String类就是这种情况

final修饰变量

表示该变量只能被赋值一次

成员变量、局部变量都可以使用final修饰(其中成员变量必须在声明时赋值或者通过构造方法赋值,变成一个常量。局部变量可以不在声明的时候赋值,但是也只能赋值一次)

必须手工为变量赋值一次(包括成员变量,如果赋默认值,没有任何意义)

final修饰方法表示该方法不能被子类重写

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值