内部类
1.1、内部类非静态:在外部类的非静态方法中创建内部类的实例。
- public class InnerClass {
- class A{
- int a = 10;
- void b(){
- System.out.println("this is A.b()!");
- }
- }
- void build(){
- A a = new A();
- a.b();
- }
- public static void main(String[] args) {
- InnerClass ic = new InnerClass();
- ic.build();
- }
- }
1.2、内部类非静态:在外部类的静态方法中创建内部类的实例。
- public class InnerClass {
- class A{
- int a = 10;
- void b(){
- System.out.println("this is A.b()!");
- }
- }
- public static void main(String[] args) {
- InnerClass ic = new InnerClass();
- InnerClass.A aa = ic.new A();
- aa.b();
- }
- }
2、内部类静态:在外部类的静态方法中创建内部类的实例。
- public class InnerClass {
- static class A{
- int a = 10;
- void b(){
- System.out.println("this is A.b()!");
- }
- }
- public static void main(String[] args) {
- InnerClass.build();
- }
- static void build(){
- A a = new A();
- a.b();
- }
- }
3、在内部类的非静态方法中创建外部类的实例。(使用外部类.this来创建外部类的实例)
- public class InnerClass {
- class A{
- int a = 10;
- void build(){
- InnerClass ic = InnerClass.this;
- ic.a();
- }
- }
- void a(){
- System.out.println("this is InnerClass.a()!");
- }
- }
4、在内部类的静态方法中创建外部类的实例。(直接通过new来创建)
- public class InnerClass {
- static class A{
- int a = 10;
- static void build(){
- InnerClass ic = new InnerClass();
- ic.a();
- }
- }
- void a(){
- System.out.println("this is InnerClass.a()!");
- }
- }
5、在其它类中创建内部类实例。(重点)
- public class InnerClass {
- class A{
- void a(){
- System.out.println("this is A.a()!");
- }
- }
- static class C{
- void c(){
- System.out.println("this is C.c()!");
- }
- }
- }
- class B{
- public static void main(String[] args){
- /*创建非静态内部类*/
- InnerClass ic = new InnerClass();
- A a = ic.new A();
- a.a();
- /*创建静态内部类*/
- C c = new C();
- c.c();
- }
- }
匿名内部
使用匿名内部类应该注意:
a) 匿名内部类不能有构造方法
b) 匿名内部类不能定义任何静态成员、方法和类。
c) 匿名内部类不能是public,protected,private,static。
d) 只能创建匿名内部类的一个实例。
e) 一个匿名内部类一定是在new的后面,用其隐含实现一个接口或实现一个类。
f) 因匿名内部类为局部内部类,所以局部内部类的所有限制都对其生效。
java中的匿名内部类总结
匿名内部类也就是没有名字的内部类
正因为没有名字,所以匿名内部类只能使用一次,它通常用来简化代码编写
但使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口
实例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
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接口的匿名内部类实现
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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