- 》创建一个class前写abstract关键字的抽象类,抽象类不能创建对象,只能创建其非抽象子类的对象。如本例抽象类名为 “形状类型”,我们的最终目的是计算这个形状的面积。注意:含有抽象方法的类必须是抽象类,但抽象类不一定要有抽象方法。
- 》抽象类中可以有抽象方法,抽象方法没有方法体(直接分号结尾没大括号)。如本例中的第一个方法:使用简单公式计算面积,可传入的参数为a。由于不知道具体形状,无法找到简单公式来计算面积,故为抽象方法。
- 》抽象类中也可以有普通成员方法,即不带abstract关键字的方法。如本例中的第二种方法:使用积分计算面积。不管图形的形状是什么,都可以通过积分求解面积,故为非抽象方法。
public abstract class ShapeType {
public abstract double calculateAreaUsingSimpleFormula(double a);
public void useIntegralToCalculateArea() {
System.out.println("执行积分计算面积");
}
}
- 》创建一个子类,继承抽象类(不带abstract)。如本例中我们确定了需要求解的是一个圆形的面积。我们要把这个子类变成非抽象类。
- 》对父类中的所有抽象方法进行覆盖重写(不带abstract),可借助在方法前的@Override检验是否成功对抽象方法进行了重写。如本例一旦知道了计算的是圆的面积,就能想到可用简单公式为 S=Pi*r2 来计算面积。另外,如果不对所有抽象方法进行重写,而是把这个子类用abstract修饰后也当抽象类,那是可行的。可以继续创建这个(带abstract)子类的(不带abstract)子类来继续覆盖重写剩下的抽象方法,进而实例化对象来使用。
public class RoundType extends ShapeType {
@Override
public double calculateAreaUsingSimpleFormula(double r) {
double S = Math.PI * Math.pow(r, 2);
return S;
}
}
- 》新建一个main方法,new出一个子类的对象。子类是圆形,实例化的对象名为round。
- 》通过这个子类的对象,对父类的抽象方法进行使用。下面的程序输出的结果为:
113.09733552923255(=Pi*62)
执行积分计算面积
public class Demo {
public static void main(String[] args) {
RoundType round = new RoundType();
System.out.println(round.calculateAreaUsingSimpleFormula(6));
round.useIntegralToCalculateArea();
}
}