繁体   English   中英

理解java中的有界泛型。 重点是什么?

[英]Understanding bounded generics in java. What is the point?

我试图理解有界类型,但不太了解它们的重点。

有一个有界泛型的例子,它提供了这个用例:

public class NaturalNumber<T extends Integer> {

    private T n;

    public NaturalNumber(T n)  { this.n = n; }

    public boolean isEven() {
        return n.intValue() % 2 == 0;
    }

    // ...
}

如果您要限制可以是参数化类型的类,为什么不一起忘记参数化并具有:

public class NaturalNumber {

    private Integer n;

    public NaturalNumber(Integer n)  { this.n = n; }

    public boolean isEven() {
        return n.intValue() % 2 == 0;
    }

    // ...
}

然后任何扩展/实现Integer都可以与这个类一起使用。

另外,一个附带问题:当 Java Integer类是 final 时, T如何在第一个示例中扩展Integer

当 Java Integer 类是 final 时,T 如何在第一个示例中扩展 Integer?

T只能是Integer ,所以这里的“扩展”纯粹是象征性的。 (我从旁注开始,因为事实上,这是一个泛型无用的例子。我真的不知道为什么教程认为这是一个信息丰富的演示。它不是。)


假设T extends Number

class Example<T extends Number> {
    private T num;

    void setNum(T num) { this.num = num; }
    T    getNum()      { return num;     }
}

所以泛型的要点是,你可以这样做:

Example<Integer> e = new Example<>();
e.setNum( Integer.valueOf(10) );
// returning num as Integer
Integer i = e.getNum();
// and this won't compile
e.setNum( Double.valueOf(10.0) );

泛型是参数多态的一种形式,从本质上讲,它让我们可以重用有关所涉及类型的通用性代码。

那么边界有什么意义呢?

一个在这里势必意味着T必须是Number或子类Number ,所以我们可以调用的方法Number上的一个实例T 不幸的是, Number本身通常是一个无用的基类(因为精度问题),但它可能让我们做一些有趣的事情,例如:

class Example<T extends Number> extends Number {
//                              ^^^^^^^^^^^^^^
    ...
    @Override
    public int intValue() {
        return num.intValue();
    }
    // and so on
}

例如,更常见的是找到T extends Comparable<T> ,这让我们可以用T做一些更有意义的事情。 我们可能有这样的事情:

// T must be a subclass of Number
// AND implement Comparable
Example<T extends Number & Comparable<T>>
        implements Comparable<Example<T>> {
    ...
    @Override
    public int compareTo(Example<T> that) {
        return this.num.compareTo(that.num);
    }
}

现在我们的Example类有了一个自然的排序。 我们可以对它进行排序,即使我们不知道T在类体内究竟是什么。

如果我们结合这些概念,那就:

  • 泛型允许“外部世界”指定实际类型和
  • 界限允许“内部世界”使用共性,

我们可以构建结构,例如:

static <T extends Comparable<T>> T min(T a, T b) {
    return (a.compareTo(b) < 0) ? a : b;
}

{
    // returns "x"
    String s = min("x", "z");
    // returns -1
    Integer i = min(1, -1);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM