如何彻底理解Java抽象类 为什么要用抽象类 什么情况下用抽象类
呐,到底什么是抽象类,有时明明一个普通类就可以解决了,为啥非得整个抽象类,装逼吗
我曾带着这样的疑惑,查了很多资料,看了很多源码,写了很多代码,以下是我的理解
一、彻底理解Java抽象类
当我们无法理解一个事物的时候,我们得追寻他的根源: 万物皆对象
在面向对象的概念中,世间万物通过类来描绘的,但如果一个类中没有包含足够的信息来描绘一个具体的事物对象,这样的类就是抽象类。(参考 https://www.runoob.com/java/java-abstraction.html)
无论你在其他渠道看到过多少关于抽象类的解释,都没有这样解释合乎根本!
( 猪狗牛羊鸟器车 的例子就不要看了,都是一些教科书上没有任何 实操意义 的例子,看了你最终也不明白是啥玩意儿)
让你设计一个简单的学生选课系统
基本需求:学生选课,老师授课,每个老师只能接受有限个个学生,每个学生只能选一个老师。
最终会抽象出其中2个领域对象:学生、老师。当我们用类去描述学生、老师时,他们的共性是人(Person):有名字、年龄、职业等特征,有上课(学习、授课都属于上课)等行为;
public abstract class Person { protected String name; protected int age; protected int profession; public abstract void goToClass(); }
呐,我们想想,光有这些特性、行为,就能完整的描述出一个可在选课系统,操作的对象(学生或老师)吗?显然不行!学生(Student)还需要:所选课程、选中的老师等其他特征;老师(Teacher)还需要:学生限数、名下学生等其他特征,加上这些东西,才能完整的描述一个可供操作的对象!所以 Person类理应作为抽象类,goToClass方法是子类必须重写的方法,表明子类是去学习的,还是上课的。
public class Student extends Person { private int selLesson; private int selTeacher; @Override public void goToClass() { System.out.println("偶是学生,偶来听课的"); } }
public class Teacher extends Person { private int studentNumLimit; private List<String> students; @Override public void goToClass() { System.out.println("偶是老师,偶来讲课"); } }
二、为什么要用抽象类 什么情况下用抽象类
1、根本原因:无法完整描述一个事物的类
2、抽象类有一个特征,其抽象方法,必须在子类重写(子类非抽象类),所以,当我们父类的方法,必须要子类重写实现时,用抽象类。如上面的 goToClass() 方法,学生、老师去课堂的目的完全不同,必须自己实现。
3、跟接口相比,接口的方法必须由实现类全部实现,接口方法比较多时,就会麻烦, 而抽象类没有这样的限制 。比如jdk 里面的 AbstractList,是ArrayList 的父类,里面全是方法,你只需要重写自己需要的
4、易于理解,有时候,这样的设计,让人更容易理解它的层级等。 个人认为所有的设计原则都是死的,为了提高代码的实操性,牺牲部分设计原则是可以的