最近无意间发现一种对象的初始化方法:匿名内部类初始化法
List<String> list = new ArrayList<String>(){{
add("爱飘de小子");
add("flyingkid");
}};
Map<String,Object> map = new HashMap<String, Object>(){{
put("name","爱飘de小子");
put("age",24);
}};
还有这种操作!!! 我尽然不知道有这种优雅的初始化法。于是研究如下:
这种方式采用匿名内部类初始化对象,List<String> list = new ArrayList<String>(){{ ... }} , 其中 new ArrayList<String>(){{ ... }} , 再堆内存中创建的对象并不是ArrayList对象, 而是继承于ArrayList对象的匿名内部类。
第一层花括号含义: 定义匿名内部类,继承于ArrayList。
List<String> list = new ArrayList<String>(){
//此时以完成匿名内部类的定义,并未初始化内部类实例,可以重写父类ArrayList的方法
@Override
public boolean add(String s) {
return super.add(s);
}
//匿名内部类自定义方法, 仅供内部使用,毫无意义
public boolean selfAdd(String s) {
return super.add(s);
}
};
第二层花括号含义: 匿名内部类实例初始化。
List<String> list = new ArrayList<String>(){
{
//实例已完成初始化,可以直接调用父类的方法,也可以调用内部类自定义方法
super.add("爱飘de小子");
selfAdd("flyingkid");
}
//匿名内部类自定义方法, 仅供内部使用,毫无意义
public boolean selfAdd(String s) {
return super.add(s);
}
};
需要注意的是继承与ArrayList必须制定类型,否则编译器变异不通过。
引发的问题:
- List<String> list = new ArrayList<String>(){{ ... }} , 其中list并不是ArrayList的引用,而是ArrayList子类的引用。子类和 ArrayList的功能一样。而且子类的数据不是通过引用去赋值,而是通过自身的初始化。写法简介,虚拟机编译后并不简洁
2.还可能造成内存泄露,序列化时可能会出现一些问题(网上说的)
结论:
虽然在阿里巴巴java开发手册中并没有提到匿名内部类初始化法,但是在开发过程过能不用,尽量不要用。