java虚拟机(八)语法糖

语法糖可以看成是编译器实现的一些功能。他们帮我们程序员特高代码开发效率。

如泛型:

泛型擦除前

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);
}

发布了82 篇原创文章 · 获赞 49 · 访问量 12万+

猜你喜欢

转载自blog.csdn.net/xu505928168/article/details/98940470