匿名内部类(转载)


1、接口方式

匿名内部类是在抽象类及接口的概念之上发展起来的。主要目的就是减少类的定义,如下代码所示:
现在不使用匿名内部类完成:
Java代码
interface A{
public void print() ;
}
class B implements A{
public void print(){
System.out.println("Hello World!!!") ;
}
};
class C{
public void fun(A a){
a.print() ;
}
public void fun(){
this.fun(new B()) ;
}
};
public class Demo15{
public static void main(String args[]){
new C().fun() ;
}
};

interface A{
public void print() ;
}
class B implements A{
public void print(){
System.out.println("Hello World!!!") ;
}
};
class C{
public void fun(A a){
a.print() ;
}
public void fun(){
this.fun(new B()) ;
}
};
public class Demo15{
public static void main(String args[]){
new C().fun() ;
}
}; 但是现在假设说 B 类只使用一次,那问是否还有必要进行单独的声明呢?则会发现如果声明了 B 类,对于代码没有太多的必要,所以此时就可以使用匿名内部类了:


Java代码
interface A{
public void print() ;
}
class C{
public void fun(A a){
a.print() ;
}
public void fun(){
this.fun(new A(){
public void print(){
System.out.println("Hello World!!!") ;
}
}) ;
}
};
public class Demo15{
public static void main(String args[]){
new C().fun() ;
}
};

interface A{
public void print() ;
}
class C{
public void fun(A a){
a.print() ;
}
public void fun(){
this.fun(new A(){
public void print(){
System.out.println("Hello World!!!") ;
}
}) ;
}
};
public class Demo15{
public static void main(String args[]){
new C().fun() ;
}
}; 如果现在方法中,有参数了,问匿名内部类是否可以访问呢?
Java代码
interface A{
public void print() ;
}
class C{
public void fun(A a){
a.print() ;
}
public void fun(int i){
this.fun(new A(){
public void print(){
System.out.println("Hello World!!! i = " + i) ;
}
}) ;
}
};
public class Demo17{
public static void main(String args[]){
new C().fun(10) ;
}
};

interface A{
public void print() ;
}
class C{
public void fun(A a){
a.print() ;
}
public void fun(int i){
this.fun(new A(){
public void print(){
System.out.println("Hello World!!! i = " + i) ;
}
}) ;
}
};
public class Demo17{
public static void main(String args[]){
new C().fun(10) ;
}
}; 编译时会出现以下的错误:
Java代码
Demo17.java:11: 从内部类中访问局部变量 i;需要被声明为最终类型
System.out.println("Hello World!!! i = " + i) ;
^
1 错误

Demo17.java:11: 从内部类中访问局部变量 i;需要被声明为最终类型
System.out.println("Hello World!!! i = " + i) ;
^
1 错误 如果要想从方法中定义的内部类,访问方法中的参数,则方法参数的声明处必须加“ final ”。
public void fun(final int i) ;
注意:
此 final 表示的不是常量,只是一个标记而已。


----------------------------------------------------------------------
使用匿名内部类课使代码更加简洁、紧凑,模块化程度更高。内部类能够访问外部内的一切成员变量和方法,包括私有的,而实现接口或继承类做不到。然而这个不是我说的重点,我说的很简单,就是匿名内部类的两种实现方式:第一种,继承一个类,重写其方法;第二种,实现一个接口(可以是多个),实现其方法。 下面通过代码来说明:
Java代码
1. public class TestAnonymousInterClass{
2. public static void main(String args[]){
3. TestAnonymousInterClass test=new TestAnonymousInterClass();
4. test.show();
5. }
6. //在这个方法中构造了一个匿名内部类
7. private void show(){
8. Out anonyInter=new Out(){// 获取匿名内部类实例
9.
10. void show(){// 重写父类的方法
11. System.out.println("this is Anonymous InterClass showing.");
12. }
13. };
14. anonyInter.show();// 调用其方法
15. }
16. }
17.
18. // 这是一个已经存在的类,匿名内部类通过重写其方法,将会获得另外的实现
19. class Out{
20. void show(){
21. System.out.println("this is Out showing.");
22. }
23. }

1. public class TestAnonymousInterClass{
2. public static void main(String args[]){
3. TestAnonymousInterClass test=new TestAnonymousInterClass();
4. test.show();
5. }
6. //在这个方法中构造了一个匿名内部类
7. private void show(){
8. Out anonyInter=new Out(){// 获取匿名内部类实例
9.
10. void show(){// 重写父类的方法
11. System.out.println("this is Anonymous InterClass showing.");
12. }
13. };
14. anonyInter.show();// 调用其方法
15. }
16. }
17.
18. // 这是一个已经存在的类,匿名内部类通过重写其方法,将会获得另外的实现
19. class Out{
20. void show(){
21. System.out.println("this is Out showing.");
22. }
23. }
程序运行的输出结果为:



this is Anonymous InterClass showing.



所以在这里看出,匿名内部类有了自己的实现。其实很简单,使用匿名内部类是因为我这地方需要有点什么特殊的实现,所以我就在这地方把具体实现也给了出来了。 然后我就在这地方获取它的实例,调用它的方法。

接口的方式,只要把父类换成接口就行了,没必要给出代码了。



使用匿名内部类时我们不要忘了我们的目的,我们只是在这地方想对某个类有特殊的实现。 而不要想得太多,在匿名内部编写其它的方法。在匿名内部类中编写的自己的方法是不可见的。此种做法是毫无意义的,当然一般也不会这么做。在这里只是告诉初学者对于匿名内部类不要想的太多,而要这么想:匿名内部类就是重写父类或接口的方法。



匿名内部类是没有名字的,所以我们没办法获得其类型,而只能把它当作超类或接口类型来使用。



当然,我这篇文章不是很有深度。欢迎发表意见!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值