匿名内部类的作用,不需要让接口再创建文件对抽象方法进行覆盖重写
如果接口的实现类,或者是父类的子类,只需要使用唯一的一次。
那么这种情况下就可以省略该类的定义,而改为使用(匿名内部类)。
匿名内部类的定义格式:
接口名称 对象名 = new 接口名称(){
//覆盖重写所有抽象方法
};
public class DemoMain {
public static void main(String[] args) {
//使用匿名内部类
MyInterface obj = new MyInterface() {
@Override
public void method() {
System.out.println("匿名内部类实现了方法!");
}
};
obj.method();
}
}
public interface MyInterface {
public abstract void method(); //抽象方法
}
对格式"new 接口名称(){…}"进行解析:
- new代表创建对象的动作
- 接口名称就是匿名内部类需要实现哪个接口
- {…}这才是匿名内部类的内容
还要注意几点问题:
- 匿名内部类:在创建对象的时候,只能使用唯一一次。
如果希望多次创建对象,而且类的内容一样的话,那么就必须使用单独的实现类了。 - 匿名对象,在(调用方法)的时候,只能调用唯一一次。
如果希望同一对象,调用多次方法,那么必须给对象起个名字。 - 匿名内部类是省略了(实现类/子类名称),但是匿名对象是省略了(对象名称)
强调:匿名内部类和匿名对象不是一回事!!!
public class DemoMain {
public static void main(String[] args) {
// MyInterface obj = new MyInterfaceImpl();
// obj.method();
//使用匿名内部类,但不是匿名对象,对象名称就叫objA
MyInterface objA = new MyInterface() {
@Override
public void method1() {
System.out.println("匿名内部类实现了方法!111-A");
}
@Override
public void method2() {
System.out.println("匿名内部类实现了方法!222-A");
}
};
objA.method1();
objA.method2();
System.out.println("============");
//使用了匿名内部类,而且省略了对象名称,也是匿名对象
new MyInterface() {
@Override
public void method1() {
System.out.println("匿名内部类实现了方法!111-B");
}
@Override
public void method2() {
System.out.println("匿名内部类实现了方法!222-B");
}
}.method1();
//因为匿名对象无法调用第二次方法,所有需要再创建一个匿名内部类的匿名对象。
}
}