程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

在泛型类中排序

发布于2021-09-09 17:10     阅读(1171)     评论(0)     点赞(3)     收藏(5)


我正在创建一个通用类,该类具有一个方法,该方法应该对可能是 Book 或 CD 的数组集合进行排序。我在两个类型类中实现了 Comparable 并尝试对 GenericCollection 类中的数组进行排序。

我的方法现在看起来像这样:

public void sort(){
    for (int i = 0; i < collection.length; i++) {
        for (int j = 0; j < collection.length; j++) {
            if (((T)collection[i]).compareTo((T)collection[j]) > 0){
                T t = (T)collection[i];
                collection[i] = collection[j];
                collection[j] = t;
            }                   
        }
    }
}

这给了我 Object 不可比较的错误。如果我尝试强制转换为 T 类型,那么我会收到未为 CompareTo 定义 T 的错误。如果我尝试类似的事情:

<T extends Comparable>

我可以编译,但即使我在使用此类的两种类型中都定义了 Comparable,我仍然收到运行时错误。

如何让通用类型能够在它们自己的类中运行 compareTo 方法。

谢谢你的帮助。


解决方案


如果您需要实现自己的排序算法,请尝试将泛型集合类的类型参数声明为

 <T extends Comparable<T>>

这意味着,您的类将被声明为:

 class GenericCollection<T extends Comparable<T>> {  ... }

当然,你的书或 CD 类应该实现这个确切的类型:

 class Book implements Comparable<Book> { ... }

 class CD implements Comparable<CD> { ... }

如果您使用参数<T extends Comparable>,则您使用的是原始类型,这些仅用于与旧(预泛型)代码兼容,不应在新代码中使用。



所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.javaheidong.com/blog/article/283872/4c76f270a18d2629c497/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

3 0
收藏该文
已收藏

评论内容:(最多支持255个字符)