这博主第二次谈继承,如果感兴趣可以看看第一次的内容java的继承和多态_java实现多态,继承-CSDN博客
继承的概念
Dog和Cat可以继承Animal中的量,从而在不用写animal中含有的量,但如果在Animal中的含有静态变量,则无法继承,因为静态修饰的量是属于Animal这个类的,不属于其他类。
子类继承父类之后必须有属于子类的新的变量,否则继承就没有意义了(相当与如果没有新的变量,直接引用父类就可以了。)
子类与父类的关系
在子类与父类同时有相同成员变量时,采用就近原则,优先使用子类的成员变量。
class people{
int age = 10;
}
class student extends people{
int age = 15;
String sex ="nu";
public void fun(){
System.out.println(age);
}
}
public class boke1 {
public static void main(String[] args) {
student student = new student();
student.fun();
}
}
如此时fun()方法打印age的值为“15”.
super关键字
如果在子父类同时有成员变量的情况下,又想使用父类,则可以在成员变量前加上一个super。
class people{
int age = 10;
}
class student extends people{
int age = 15;
String sex ="nu";
public void fun(){
System.out.println(super.age);
}
}
public class boke1 {
public static void main(String[] args) {
student student = new student();
student.fun();
}
}
加上super之后打印结果就为父类中赋值的“10”.
this和super无法在静态下使用,因为this和super后需要跟上成员变量,但静态是属于类的。以上成员方法同样适用。
子类与父类的构造方法
当父类进行构造方法后,子类会报错,原因是父类含有构造方法,但在继承时没有给父类的构造方法进行初始化。此时如想不报错则需要在子类构造方法中进行改变。
构造方法带参数
1.报错
2.子类补充构造方法后报错解除
此时运用super()对父类进行初始化,注意的是在写子类构造方法时是含参数,因为子类总是继承父类的。Super()一定要写在子类构造方法中的第一行。
构造方法不带参数与默认值
当父类写了一个不带参数的构造方法时,在子类中可以不用写super(),编译器会自动在子类构造方法中补充,只是不显示。
此时若对Dog类中的任意对象的从父类继承过来的属性进行打印,可以看到打印出的是默认值,因为Dog 的构造方法中并未对age和string进行this的修饰,虽然在对象的赋值时进行了赋值,但事实上并没有把值赋到相关属性中。
数据类型 | 默认值 |
---|---|
byte |
0
|
char |
'\u0000'
|
short | 0 |
int | 0 |
long | 0L |
boolean
|
false
|
float
|
0.0f
|
double
|
0.0
|
reference
|
null
|
如果在dog的构造方法中加上this.age,进行tthis修饰后,这会赋Dog类在对对象赋的值。
实例化
左边为父类的静态,实例,构造,右边为子类静态,实例,构造
执行顺序为:142356
这里用一张图来解释
看完图应该不难理解,执行前后遵循先静态,后父类,最后子类
静态,实例,构造都是依托在对象身上取实现的,那么此时出现多个对象情况会有不同吗?
Dog类有两个对象dog和dog2
对象dog遵循以上实例的循序先静态,后父类,最后子类。但是dog2就不同了,循序为先父类后子类,没有了静态。
原因是静态代码块只执行一次,再dog中静态代码块已经执行过了,所以再dog2中不会出现1 ,4。
此处再谈继承到此结束。感谢观看,希望能给各位带来一些有用的东西。如果觉得博主写的还可以,不妨点个免费的赞,谢谢!