Java 里泛型的<>什么时候不需要加?

2017-07-06 00:22:58 +08:00
 guyeuro

譬如

    public class Entry<K,V> {
        K key;
        V value;

        public Entry(K key, V value){
            this.key = key;
            this.value = value;
        }

        boolean equals(Entry e){
            return (this.key == e.getKey() && this.value == e.getValue());
        }
    }

这里面这个 equals 函数里的 Entry 加<>和不加<>有区别吗? 然后这三种情况 1 不加 2 加<> 3 加<K,V> 什么时候该用哪个有什么规则吗? 是不是加<K,V>是最保险的?

2364 次点击
所在节点    问与答
7 条回复
vingz
2017-07-06 00:27:49 +08:00
mark,等着 java 老司机回答
wuyukai
2017-07-06 00:59:42 +08:00
类定义加,构造函数不加,第三个属于省略了
geelaw
2017-07-06 02:15:50 +08:00
泛型方法定义和泛型类定义中只有需要新的泛型参数的时候才需要加。

例如

class G<T>
{
T t;
void G2<T2>(T2 t2)
{
T2 t3 = t2;
}
}

调用泛型方法,通常参数可以推断,不需要加;此外,因为类型擦除的缘故,编译器可以简单地把所有参数都推断为 Object。

定义泛型类的实例,不加应该是默认 Object,但我不确定。由于类型擦除的缘故,下面这个是正确的:

G g = new G<Integer>();

说到底,这个问题并不重要,因为 Java 的泛型参数是擦除的。如果你不确定,可以选择加或者不加,然后尝试编译,或者看 IDE 提示。
Perry
2017-07-06 02:21:49 +08:00
去掉之后 IDE 会报错的要加 不然不加
😂
WhoMercy
2017-07-06 08:27:57 +08:00
你可能要了解一下“泛型擦除”,既即使加了泛型也会有类型错误的问题。

我的做法是,如果有定义泛型的类、方法,肯定是要添加,如果参数的类型广泛,可以用 Object。
声明时用 3.实例用 2.不用 1.如
Map<String,Integer> tempMap = new HashMap<>();

使用 tempMap 时就不需要强制类型转化等
zhuyao
2017-07-06 08:32:51 +08:00
不在意编译警告可以不加,不在意类造型异常可以不加
gongzhang
2017-07-06 10:06:18 +08:00
编译器警告都要在意啊~

无<...>的是旧的写法,建议都带<...>。楼主例子里面的 equals(Entry) 可以写作 Entry<?, ?>。
好像是 Java 7 开始有了一些范型的类型推断吧?可以在某些场合下省略内容,像是楼上 WhoMercy 的例子

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/373351

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX