原文:http://tjukk.iteye.com/blog/2047663
匿名内部类也就是没有名字的内部类
正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写
但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口
实例1:不使用匿名内部类来实现抽象方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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();
}
}
|
运行结果:eat something
可以看到,我们用Child继承了Person类,然后实现了Child的一个实例,将其向上转型为Person类的引用
但是,如果此处的Child类只使用一次,那么将其编写为独立的一个类岂不是很麻烦?
这个时候就引入了匿名内部类
实例2:匿名内部类的基本实现
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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();
}
}
|
运行结果:eat something
可以看到,我们直接将抽象类Person中的方法在大括号中实现了
这样便可以省略一个类的书写
并且,匿名内部类还能用于接口上
实例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 threadMethod(String name){
Thread t = new Thread(name) {
public void run() {
for (int i = 1; i <= 5; i++) {
System.out.print(Thread.currentThread().getName()+":"+i + " ; ");
}
}
};
t.start();
}
public static void main(String[] args) {
threadMethod("线程1");
threadMethod("线程2");
}
}
运行结果(不确定):线程1:1 ; 线程1:2 ; 线程1:3 ; 线程2:1 ; 线程1:4 ; 线程2:2 ; 线程1:5 ; 线程2:3 ; 线程2:4 ; 线程2:5 ;
实例5:Runnable接口的匿名内部类实现
public class Demo {
public static void threadMethod(){
Runnable r = new Runnable() {
public void run() {
for (int i = 1; i <= 5; i++) {
System.out.print(Thread.currentThread().getName()+":"+i + " ; ");
}
}
};
Thread t1 = new Thread(r, "线程1");
Thread t2 = new Thread(r, "线程2");
t1.start();
t2.start();
}
public static void main(String[] args) {
threadMethod();
}
}
运行结果(不确定):线程1:1 ; 线程2:1 ; 线程1:2 ; 线程2:2 ; 线程1:3 ; 线程2:3 ; 线程1:4 ; 线程2:4 ; 线程2:5 ; 线程1:5 ;
---------------------------------------------------------------
ps:上面的继承Thread和实现Runnable是常用的
之前没写过多线程,也记一下下面的吧
package com;
public class TestRunnable implements Runnable{
private int i = 10;
@Override
public void run() {
System.out.println("TestRunnable class "+Thread.currentThread().getName()+":"+(--i));
}
public static void main(String[] args) {
TestRunnable t1 = new TestRunnable();
TestRunnable t2 = new TestRunnable();
//执行出的结果的顺序不确定 变量i copy
new Thread(t1).start();
new Thread(t2).start();
//执行出的结果的顺序不确定 变量i 共享
/*new Thread(t1,"thread1").start();
new Thread(t1,"thread2").start();*/
}
}
执行结果:
TestRunnable class Thread-1:9
TestRunnable class Thread-0:9
TestRunnable class Thread-0:9
/*
TestRunnable class thread2:9
TestRunnable class thread1:8
TestRunnable class thread1:8
*/
package com;
public class TestRunnable1 implements Runnable{
private int i = 10;
@Override
public void run() {
System.out.println("TestRunnable1 class "+Thread.currentThread().getName()+":"+(--i));
}
public static void main(String[] args) {
TestRunnable t1 = new TestRunnable();
TestRunnable1 t2 = new TestRunnable1();
//执行出的结果的顺序不确定
new Thread(t1).start();
new Thread(t2).start();
}
}
执行结果:
TestRunnable1 class Thread-1:9
TestRunnable class Thread-0:9