5

我试图理解 Java 中的泛型方法。给定以下代码:

public class GenericTest {

    interface Shape {
        public long area();
    }

    public static class Triangle implements Shape
    {
        private long base, height;
        public long area() { return (base * height) / 2; }
    }

    public static  class Rectangle implements Shape
    {
        private long width, height;
        public long area() { return width * height; }
    }

    public <T extends Shape> long area1(T shape)
    {
        return shape.area();
    }

    public long area2(Shape shape)
    {
        return shape.area();
    }

}

我看不到/理解为什么我应该使用/实现 area1 而不是 area2(反之亦然)。我错过了什么吗?两种方法不做同样的事情吗?

它让我对 Java 中的泛型感到有些困惑

4

3 回答 3

13

在您的示例中,由于T类型参数未在任何返回值中使用,因此没有区别。

但是,假设您有以下方法:

public <T extends Shape> T movedShape1(T shape) {
    return shape.move();
}

public Shape movedShape2(Shape shape) {
    return shape.move();
}

在这里您可以看到使用movedShape1(). 您可以为返回值获得更具体的类型,而不会失去任何类型安全性。

于 2013-05-20T19:09:34.157 回答
4

area1创建该方法没有充分的理由。该area2方法是优选的。当与特定但未知的类型存在关系时,将使用泛型。在这里,没有关于参数的具体内容shape。该接口Shape已经允许我们使用该area方法,因此我们不关心Shape作为shape. 所以这里不需要泛型。

利用

public long area2(Shape shape)
于 2013-05-20T19:08:35.443 回答
0

在这种情况下-形状不是(抽象)类而是接口,因此必须实现它(以泛型思维形式扩展)-我会说它们完全相同,并且添加泛型只会掩盖真正的东西进行中

于 2013-05-20T19:09:53.183 回答