抽象类:
用关键字abstract修饰一个方法,并且只“声明”而不具体实现这个方法,就可以生成一个抽象方法:
public abstract double perimeter();
包含至少一个抽象方法的类,必须用abstract修饰,成为抽象类。
注:抽象类是不能直接实例化的,因为抽象类存在未实现的方法。
有抽象类派生出的子类,若依然有未实现的抽象方法,则子类也是抽象类。
抽象类由“确定的成分”和“不确定的成分”两部分组成。
“确定的部分”指类中固定的,固有的和确定的成员、方法,这些成分在抽象类中实现,再用派生的方式让子类继承,从而实现了“代码复用”。
“不确定的成分”是类彼此又相同又不同的部分,相同点在于:这些类都存在这些部分,不同点在于:这些成分的实现方法有所不同。
如果该类存在这么一种方法:这个方法不是由这个类产生的,或者无法确定实现过程,但是要用到这个功能以便实现其他确定的功能,那么可以把这个不确定、当前无法实现的方法声明为抽象方法,让其派生类实现它。
内部类:
在一个类中,定义其他类成为内部类。
在内部类中,可以直接引用外部类的所有方法和成员,且不受修饰符影响。
外部类可以定义内部类对象的成员。
外部类的方法,可以通过内部类的对象引用内部类的所有成员与方法。
匿名内部类:
对抽象类的“实例化”:
抽象类:
public abstract Class Bird {
private String name;
public Bird(String name) {
this.name = name;
}
public abstract String cry();
}
第一种抽象类实例化方法:
Bird lark = new Bird("bird") {
public String cry() {
return "cry";
}
}
lark.print();
即:
new 抽象类构造方法() {
实现抽象方法;
};
本质上是生成了一个类,但是这个类没有命名。故这个类为匿名类。
第二种:
new Bird("Bird") {
public String cry() {
return "cry";
}
}.print();
这种生成类方法直接省略了匿名类的对象名。
注:匿名内部类的好处:
不需要明确地生成派生类,对于简单问题可以提高编程效率;
在需要时临时产生匿名内部类,实现抽象方法,更灵活;
一个匿名内部类对应一种抽象方法的实现,更紧凑。