(转载)http://linsea.iteye.com/blog/711403
- package codelib.innerclasses;
- public interface Destination {
- String readLabel();
- }
- package codelib.innerclasses;
- /**
- * @author Administrator
- *
- */
- public class InnerClassInitTest {
- public Destination destination( final String dest, final float price){
- return new Destination() {
- private int cost;
- private String label = dest;
- {//实例初始化代码块,相当于构造器的实际效果
- cost = Math.round(price);
- if (cost > 100)
- System.out.println("Over budget!");
- }
- public String readLabel() {
- return label;
- }
- };
- }
- /**
- * @param args
- */
- public static void main(String[] args) {
- InnerClassInitTest p = new InnerClassInitTest();
- Destination d = p.destination ("Tasmania",101.34F);
- }
- }
如果匿名内部类希望使用一个在其外部定义的对象(调用父类构造器时,传入的参数除外),那么编译器要求其参数引用是final的.
构造器是与类名同名的函数,而匿名类因为没有名字,所以也就没有构造器,为了达到与构造器实例化对象的效果,可以使用代码块来进行实例初始化操作.如上例中的花括号中的代码.
匿名内部类与正规的继承相比有些受限,因为匿名内部类既可以扩展类,也可以实现接口,但是不能两者兼备.而且如果是实现接口,也只能实现一个接口.