语法糖可以看成是编译器实现的一些功能。他们帮我们程序员特高代码开发效率。
如泛型:
泛型擦除前
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put("hello", "你好");
map.put("how are you?", "吃了没?");
System.out.println(map.get("hello"));
System.out.println(map.get("how are you?"));
}
擦除后:
public static void main(String[] args) {
Map map = new HashMap();
map.put("hello", "你好");
map.put("how are you?", "吃了没?");
System.out.println((String) map.get("hello"));
System.out.println((String) map.get("how are you?"));
}
可以看到,泛型类型都变回了原生类型
所以可以知道List<String> 和List<Integer>的原生类型是一样的。都是List<E>
那如果方法重载的时候,怎么区分呢?
public class GenericTypes {
public static void method(List<String> list) {
System.out.println("invoke method(List<String> list)");
}
public static void method(List<Integer> list) {
System.out.println("invoke method(List<Integer> list)");
}
}
这是会报错的。因为这两个方法的返回类型,和输入类型都是一模一样的。
但是如果,改变返回类型。
public class GenericTypes {
public static String method(List<String> list) {
System.out.println("invoke method(List<String> list)");
return "";
}
public static int method(List<Integer> list) {
System.out.println("invoke method(List<Integer> list)");
return 1;
}
public static void main(String[] args) {
method(new ArrayList<String>());
method(new ArrayList<Integer>());
}
}
就能输出
invoke method(List<String> list)
invoke method(List<Integer> list)
这是通过返回参数不同。
有人有疑问了。方法重载要求方法具备不同的特征签名,但是特征签名却不包括返回值。
不过在class文件格式中,只要描述符不完全一样。比如返回值不一样不同。就能共存在一个class文件之中。
当然,泛型的引入也对虚拟机做出了很多改变。有个属性能保存的参数类型并不是原生类型。
再来个例子
public static void main(String[] args) {
List<Integer> list = Arrays.asList(1, 2, 3, 4);
// 如果在JDK 1.7中,还有另外一颗语法糖 ,
// 能让上面这句代码进一步简写成List<Integer> list = [1, 2, 3, 4];
int sum = 0;
for (int i : list) {
sum += i;
}
System.out.println(sum);
}
解语法糖后
public static void main(String[] args) {
List list = Arrays.asList( new Integer[] {
Integer.valueOf(1),
Integer.valueOf(2),
Integer.valueOf(3),
Integer.valueOf(4) });
int sum = 0;
for (Iterator localIterator = list.iterator(); localIterator.hasNext(); ) {
int i = ((Integer)localIterator.next()).intValue();
sum += i;
}
System.out.println(sum);
}