package vehicles_order;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
public class vehicles implements Comparable {
String Vehicle;
String Make;
String Type;
double Cost;
public static void main(String[] args){
ArrayList cars = new ArrayList();
cars.add(new vehicles ("CAR","Peugot","3008",12500.00));
cars.add(new vehicles ("CAR","BMW","316",4995.00));
cars.add(new vehicles ("CAR","Ford","Fiesta",2995.00));
Collections.sort(cars);
Iterator itr = cars.iterator();
while(itr.hasNext()){
Object element = itr.next();
System.out.println(element + "\n");
}
}
public vehicles(String vehicle, String make, String type, double cost){
Vehicle = vehicle;
Make = make;
Type = type;
Cost = cost;
}
public String toString() {
return "Vehicle: " + Vehicle + "\n" + "Make: " + Make + "\n" + "Type: " + Type + "\n" + "Cost: " + Cost;
}
public int compareTo(Object o1) {
if (this.Cost == ((vehicles) o1).Cost)
return 0;
else if ((this.Cost) > ((vehicles) o1).Cost)
return 1;
else
return -1;
}
}
我的比较器位于底部,我只是想知道它实际上是如何工作的。我猜它就像一个堆栈,当它返回 1 时,如果它的 -1 向下移动,它就会向上移动堆栈。
另外,谁能告诉我如何通过不同的方法订购汽车。例如,将成本存储在临时最高值中,并检查新值是否高于当前值
什么是可比较接口?它是一个包含单个方法的接口:
compareTo(T o)
为 Java 提供将您的对象与任何其他对象进行比较的功能。基本上,您想将您的对象与同类(类)的对象进行比较。所以有一个通常的签到相比于执行:
if (o instanceof vehicles) {
Vehicles v = (Vehicles)o;
// compare
} else {
return false;
}
然后,在比较部分,您应该根据您的业务规则决定其他车辆是否与您的对象相同,或多或少。
- 0 - 如果它们相等;
- 1 - 如果你的物体更大;
- -1 - 如果你的物体较小。
一切就这么简单!
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)