假设我有这个课程:

public class Bucket<T> {
        T filling;
}


并且filling属性可以是以下任意一个的实例:

public class Oil{
    float volume;
}


要么

public class Water{
    float volume;
}


在我的代码的一部分中,我有一个存储桶列表:

LinkedList<Bucket> list;


现在,我想通过属性“ volume”对“ list”(Bucket)的元素进行排序。
但是我无法比较T.volume。那么,我该怎么做呢?

抱歉,如果我的问题很愚蠢,我仍在学习Java。

最佳答案

我回答您是假设这是一个理论问题,我不建议您实施该方法,而要找到一种更好的模式来完成您想要的事情。

您想对存储桶列表进行排序。要调用Collections.sort()方法,Bucket需要实现Comparable(并因此定义compareTo方法)。

您应该定义一个由“填充”元素实现的接口

interface Element {
    float getVolume();
    void setVolume(float volume);
}


class Oil implements Element {
    float volume;

    @Override
    public float getVolume() {
        return volume;
    }

    @Override
    public void setVolume(float volume) {
        this.volume = volume;
    }
}


class Water implements Element {
    float volume;

    @Override
    public float getVolume() {
        return volume;
    }

    @Override
    public void setVolume(float volume) {
        this.volume = volume;
    }
}


现在,您可以定义Bucket类:

class Bucket implements Comparable<Bucket> {
    Element filling;

    @Override
    public int compareTo(Bucket o) {
        return Float.compare(filling.getVolume(), o.filling.getVolume());
    }
}


这段代码:

public static void main(String[] args) {
    List<Bucket> elems = new LinkedList<>();
    Bucket o = new Bucket();
    o.filling = new Oil();
    o.filling.setVolume(5);

    Bucket w = new Bucket();
    w.filling = new Water();
    w.filling.setVolume(12);

    elems.add(w);
    elems.add(o);
    Collections.sort(elems);
    for(Bucket b: elems) {
        System.out.println(b.filling.getVolume());
    }
}


将打印:

5.0
12.0


让我感到羞耻的是,我编写了整个代码,但阅读此代码比阅读我可能会写的错误解释要容易得多。

09-10 05:57
查看更多