回答:匿名内部类在实现时必须借助一个借口或者一个抽象类或者一个普通类来构造,从这过层次上讲匿名内部类是实现了接口或者继承了类,但是不能通过extends或implement关键词来继承类或实现接口。
匿名内部类即没有名字的内部类。当我们只需要用某一个类一次时,且该类从意义上需要实现某个类或某个接口,这个特殊的扩展类就以匿名内部类来展现。
一般的用途:
1、覆盖某个超类的方法,并且该扩展类只在本类内用一次。
2、继承抽象类,并实例化其抽象方法,并且该扩展类只在本类内用一次。
3、实现接口,实例化其方法,并且该扩展类只在本类内用一次。
代码示例:
class Car{
void move(){}
}
interface Person{
void learn();
}
abstract class Animal{
abstract void eat();
}
public class AnonymousInnerClassDemo {
public static void main(String[] args) {
Car car = new Car(){
@Override
void move() {
System.out.println("匿名内部类的move方法");
}
};
car.move();
Person person = new Person() {
public void learn() {
System.out.println("匿名内部类的learn方法");
}
};
person.learn();
Animal animal = new Animal() {
@Override
void eat() {
System.out.println("匿名内部类的eat方法");
}
};
animal.eat();
}
}
几点说明:
一、由于匿名内部类没有名字,所以它没有构造函数。因为没有构造函数,所以它必须完全借用父类的构造函数来实例化,匿名内部类完全把创建对象的任务交给了父类去完成。
二、在匿名内部类里创建新的方法没有太大意义,但它可以通过覆盖父类的方法达到神奇效果,如上例所示。这是多态性的体现。
三、因为匿名内部类没有名字,所以无法进行向下的强制类型转换,持有对一个匿名内部类对象引用的变量类型一定是它的直接或间接父类类型。
四、注意匿名内部类的声明是在编译时进行的,实例化在运行时进行。这意味着for循环中的一个new语句会创建相同匿名类的几个实例,而不是创建几个不同匿名类的一个实例。