Java 7中的菱形运算符(<>)有什么意义?
作者:互联网
java 7中的菱形运算符允许以下代码:
List<String> list = new LinkedList<>();
但是在Java 5/6中,我可以简单地写:
List<String> list = new LinkedList();
我对类型擦除的理解是这些完全相同. (无论如何,通用都会在运行时删除).
为什么要钻石头呢?它允许哪些新功能/类型安全?如果它没有产生任何新功能,为什么他们将其作为功能提及?我对这个概念的理解是否有缺陷?
解决方法:
这个问题
List<String> list = new LinkedList();
在左侧,您使用的是泛型类型List< String>在右侧,您使用原始类型LinkedList. Java中的原始类型实际上只存在与前泛型代码的兼容性,并且永远不应该在新代码中使用,除非
你绝对必须这样做.
现在,如果Java从一开始就具有泛型并且没有类型(例如LinkedList),它们最初是在具有泛型之前创建的,那么它可能已经使得泛型类型的构造函数自动从其中推断出它的类型参数.如果可能的话,分配的左侧.但事实并非如此,它必须以不同的方式处理原始类型和泛型类型以实现向后兼容性.这使得他们需要制作一种稍微不同但同样方便的方式来声明一个通用对象的新实例,而不必重复其类型参数……菱形运算符.
至于List< String>的原始示例list = new LinkedList(),编译器会为该赋值生成警告,因为它必须.考虑一下:
List<String> strings = ... // some list that contains some strings
// Totally legal since you used the raw type and lost all type checking!
List<Integer> integers = new LinkedList(strings);
存在泛型以提供编译时保护以防止做错事.在上面的示例中,使用原始类型意味着您没有获得此保护,并且将在运行时收到错误.这就是你不应该使用原始类型的原因.
// Not legal since the right side is actually generic!
List<Integer> integers = new LinkedList<>(strings);
但是,菱形运算符允许将赋值的右侧定义为具有与左侧相同类型参数的真正通用实例,而无需再次键入这些参数.它允许您使用与原始类型几乎相同的努力来保持泛型的安全性.
我认为要理解的关键是原始类型(没有<>)不能与泛型类型相同.声明原始类型时,您不会获得泛型的任何好处和类型检查.您还必须记住,泛型是Java语言的通用部分……它们不仅仅适用于集合的无参数构造函数!
标签:diamond-operator,java,generics,java-7 来源: https://codeday.me/bug/20190910/1802448.html