假设我有这个课程:
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
让我感到羞耻的是,我编写了整个代码,但阅读此代码比阅读我可能会写的错误解释要容易得多。