一、前言
前面我也们讲述了相关封装的,现在我们先认识的继承的概念和使用。
二、继承
什么是继承呢?
继承在显示生活中也不少见,比如继承财产之类的,在我们java学习中也有类似的使用,
继承者称作子类也叫派生类,被继承者称作父类、基类或超类,objec类是所有类的父类
(后期介绍)
继承的好处与弊端
好处:就是提高了代码的维护性(多个代码需要修改,只需要修该一处即可)。
提高了代码的复用性(多个相同的成员可以方法到同一个类中)
弊端:继承的缺点就是使代码之间的耦合度高,修改父类子类也会跟着变化
继承的使用场景?
两个有从属关系的,比如猫和动物,学生和人等。
继承的关键词是extends。
继承的格式:
public class 子类名 extends 父类名{}
举例:
1
|
public class Cat extends Animal{} //猫继承动物类
|
继承的特点:
子类可以拥有父类的非私有方法和成员变量,也可以重写父类的非私有(private修饰的)方法。所有子类的方法都默认访问父类的无参构造
重写的概念:
重写是子类重述父类中的非私有方法,重写的一般特点是方法名相同,格式相同,返回类型相同、方法体不同
如:
fu类中:
1
2
3
4
5
|
public class fu{
public void play(){
System.out.println( "fu喜欢打羽毛球" );
}
}
|
zi类中:
1
2
3
4
5
|
public class zi extends fu{
public void play(){ //对父类的方法重写
System.out.println( "zi喜欢打篮球" );
}
}
|
还可以这么写,访问权限需要zi类大于等于fu类
fu类中修饰是默认:
1
2
3
4
5
|
public class fu{
void eat(){
System.out.println( "fu中eat方法" );
}
}
|
zi类中:
1
2
3
4
5
6
|
public class Zi extends Fu {
@Override //检测方法重写的正确性
public void eat() {
System.out.println( "zi中的eat方法" );
}
}
|
zi类中重写:
1
2
3
4
5
6
|
public class Zi extends Fu {
// @Override写不写不会影响,这个只是起到辅助作用
void eat() {
System.out.println( "zi中的eat方法" );
}
}
|
zi还可以:
1
2
3
4
5
6
|
public class Zi extends Fu {
@Override
protected void eat() {
System.out.println( "zi中的eat方法" );
}
}
|
修饰访问关系:public>protected>默认(不写)>private
当父类的权限修饰符是默认(也就是不写修饰符),子类重写的修饰方法可以是默认和
默认之前的以此类推。注:当父类的权限修饰符是private时,那子类可不是private
之前的。当父类被private修饰时,子类不能重写此类方法。
super关键字
当子类中的成员变量和父类中成员变量同名时,我们想使用父类中的成员变量时,
或者我们重写了父类中方法时,我们还想调用父类中的方法时。此时我们就要使用super
关键字来调用父类中的成员。
super和this的比较
super和this的使用原理差不多,this是解决了局部变量和成员变量同名时,局部变量对
成员的覆盖super是解决子类对父类的覆盖。
当局部变量,成员变量,父类中的变量同名时,访问的是局部变量。可以用this和super改变。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
public class fu{
public int age= 40 ;
public fu(){} //无参构造
public fu( int age){ //带参构造
this .age=age;}
public void eat(){
System.out.println( "fu中eat方法" );
}
}
public class Zi extends Fu {
public int age= 18 ;
public Zi(){}
public Zi( int age){
this .age=age;}
public void eat() {
super .eat();
System.out.println( "zi中的eat方法" );
}
public void show(){
int age= 1 ;
System.out.println(age); //1局部变量的值
System.out.println( this .age); //18子类成员中的值
System.out.println( super .age); //40父类中的值
}
public class Demo{
public static void main(String[] args){
zi z= new zi();
z.eat();
z.show();
}
}
|
下篇我们继续!!
到此这篇关于Java 面向对象之继承篇详解原理与特点的文章就介绍到这了,更多相关Java 继承内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/weixin_60719453/article/details/120860763