匿名内部类也就是没有名字的内部类
正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写
但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口
实例1:不使用匿名内部类来实现抽象方法
abstract class Person {
public abstract void eat();
}
class Child extends Person {
public void eat() {
System.out.println("eat something");
}
}
public class Demo {
public static void main(String[] args) {
Person p = new Child();
p.eat();
}
}
可以看到,我们用Child继承了Person类,然后实现了Child的一个实例,将其向上转型为Person类的引用运行结果:eat something
但是,如果此处的Child类只使用一次,那么将其编写为独立的一个类岂不是很麻烦?
这个时候就引入了匿名内部类
实例2:匿名内部类的基本实现
abstract class Person {
public abstract void eat();
}
public class Demo {
public static void main(String[] args) {
Person p = new Person() {
public void eat() {
System.out.println("eat something");
}
};
p.eat();
}
}
可以看到,我们直接将抽象类Person中的方法在大括号中实现了运行结果:eat something
这样便可以省略一个类的书写
并且,匿名内部类还能用于接口上
实例3:在接口上使用匿名内部类
interface Person {
public void eat();
}
public class Demo {
public static void main(String[] args) {
Person p = new Person() {
public void eat() {
System.out.println("eat something");
}
};
p.eat();
}
}
运行结果:eat something
由上面的例子可以看出,只要一个类是抽象的或是一个接口,那么其子类中的方法都可以使用匿名内部类来实现
最常用的情况就是在多线程的实现上,因为要实现多线程必须继承Thread类或是继承Runnable接口
实例4:Thread类的匿名内部类实现
public class Demo {
public static void main(String[] args) {
Thread t = new Thread() {
public void run() {
for (int i = 1; i <= 5; i++) {
System.out.print(i + " ");
}
}
};
t.start();
}
}
运行结果:1 2 3 4 5
实例5:Runnable接口的匿名内部类实现
public class Demo {
public static void main(String[] args) {
Runnable r = new Runnable() {
public void run() {
for (int i = 1; i <= 5; i++) {
System.out.print(i + " ");
}
}
};
Thread t = new Thread(r);
t.start();
}
}
运行结果:1 2 3 4 5
以下是一个测试以及记录:
package com.jvm;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
/**
*
* @author chain
*
* (1) compareTo的两个对象不能是基本数据格式
*
* (2) 在jdk1.8下匿名内部类的写法必须重写接口所有的抽象方法,系统创建的实现类不会自动创建所有抽象方法.
*
* (3)Comparator接口有两个抽象方法,一个是compare,另一个是equals方法,但是他的equals就可以不用进行重写,这是因为:
* 所有类默认继承Object,所以该类已有了Object的equals方法,相当于重写了equals方法。
*
*/
public class anonymousClass {
public static void main(String[] args) {
List<student> list = new ArrayList<student>();
list.add(new student(10,"wanger"));
list.add(new student(10,"wanger"));
list.sort(new Comparator<student>() {
@Override
public int compare(student o1, student o2) {
// TODO Auto-generated method stub
return o1.getNum().compareTo(o2.getNum());
}
});
method1(new MyInterface() {
@Override
public void test2() {
// TODO Auto-generated method stub
System.out.println("test2");
}
@Override
public int test1() {
// TODO Auto-generated method stub
return 0;
}
});
}
public static void method1(MyInterface myInterface) {
System.out.println("to do myInteface");
}
}