JAVA中的对象拥有一个终极基类–Object,这类结构被称作为单根继承结构。
在单根继承结构中,所有对象都具有一个共用接口,所以它们都是相同的基本类型。单根继承结构保证所有对象都具备某些功能(如hashCode(),toString())。这使得语言更加灵活,也为JAVA中的垃圾回收器的实现提供了便利,因为不会出现无法确定的对象而陷入僵局。
人们通常说:导出类是基类,但基类不一定是导出类(如:正方形是几何形,但几何形不一定是正方形)。导出类不仅会继承基类的属性,还会继承基类的方法,但一般我们都会拓展导出类的方法或者重写基类提供的方法,因为导出类若只是纯粹替代基类,和基类拥有相同的属性和方法,是没有任何意义的。
当我们在处理各种类型时,通常不想关心其具体类型,比如计算几何形的面积,希望无论是正方形、三角形还是圆形,只需要调用几何形计算面积的方法,就能得到我们想要的结果。
导出类和基类都拥有相同的基础接口,导出类可以泛化成基类来看待,但处理具体问题时,仍需要导出类执行自身特定的代码。
下面,我们一起来看个例子:
public class Shape {
public void getArea() {
System.out.println("I am shape");
}
}
public class Circle extends Shape {
@Override
public void getArea() {
System.out.println("I am circle");
}
}
public class Square extends Shape {
@Override
public void getArea() {
System.out.println("I am Square");
}
}
public static void main(String[] args) {
Circle circle = new Circle();
Square square = new Square();
doSomething(circle);
doSomething(square);
}
运行结果如下:
一个非面向对象编程的编译器产生函数的函数调用会引起所谓的前期绑定,意味着编译器将产生一个具体函数名字的调用,这个调用会解析被执行代码的绝对地址。
而面向对象程序设计语言使用后期绑定的概念,当向对象发送消息时,被调用的代码直到运行时才能确定,编译器会对调用参数和返回值执行类型检查,但不知道执行的确切代码,为确保后期绑定的执行,JAVA使用一小段特殊代码替代绝对地址调用(我们会在之后的文章中介绍)从而实现多态,这便也解释了例子中无论是圆形还是矩形,通过调用基类几何形的方法都能获取到其导出类的具体实现。
本次分享至此结束,希望本文对你有所帮助,若能点亮下方的点赞按钮,在下感激不尽,谢谢您的【精神支持】。
若有任何疑问,也欢迎与我交流,若存在不足之处,也欢迎各位指正!