Java 4:按2值对数组排序
我目前正在研究Java 4中的projet,并且我必须对2个ArrayList排序。 这是ClassTest的ArrayList。Java 4:按2值对数组排序
public class ClassTest{
String code; // "01", "02" or "03".
String date; // 01/01/2001.
}
我的问题是,我必须首先按代码排序,然后按当前日期的最近日期排序。 我在Java 4,我不能使用很多东西,我通常用于排序像Comparator<ClassTest>
阵列。
有人可以帮助找到一个不太慢的算法吗?
感谢。
使用比较接口而不泛型(< ..>)
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Date;
import java.util.List;
public class CollectionSorter {
public static void main(String args[]) {
ClassTest obj1 = new ClassTest();
obj1.setCode("01");
obj1.setDate("2001-02-01");
ClassTest obj2 = new ClassTest();
obj2.setCode("01");
obj2.setDate("2001-01-01");
ClassTest obj3 = new ClassTest();
obj3.setCode("02");
obj3.setDate("2001-01-01");
List list = new ArrayList();
list.add(obj1);
list.add(obj2);
list.add(obj3);
System.out.println("Before sorting - " + list);
Collections.sort(list, new ClassTestComparator());
System.out.println("After sorting - " + list);
}
}
class ClassTest{
private String code; // "01", "02" or "03".
private String date; // 01/01/2001.
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getDate() {
return date;
}
public void setDate(String date) {
this.date = date;
}
public String toString()
{
return "[code: " + code + ", date: " + date + "]";
}
}
class ClassTestComparator implements Comparator {
public int compare(Object o1, Object o2) {
ClassTest obj1 = (ClassTest) o1;
ClassTest obj2 = (ClassTest) o2;
int code1 = Integer.parseInt(obj1.getCode());
int code2 = Integer.parseInt(obj2.getCode());
int result = 0;
if(code1 > code2) {
result = 1;
}
if(code1 < code2) {
result = -1;
}
if (result != 0) {
return result;
}
// Sort by Date ("by the closest date of the current date")
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Date date1 = null;
Date date2 = null;
try {
date1 = sdf.parse(obj1.getDate());
date2 = sdf.parse(obj2.getDate());
} catch(ParseException e) {
e.printStackTrace();
}
if(date1.compareTo(date2)>0){
result = 1;
}else if(date1.compareTo(date2)<0){
result = -1;
}else if(date1.compareTo(date2)==0){
result = 0;
}
return result;
}
}
注:代码在Java 1.4版本中测试,并按预期工作
我不知道,如果在你的Java版本,这是可能的,但也许你可以试试这个方法:
public class ClassTest implements Comparable<ClassTest> {
String code; // "01", "02" or "03".
String date; // 01/01/2001.
@Override
public int compareTo(ClassTest ct) {
// Sort by Code
result = code.compateTo(ct.code);
if (result != 0){return result;}
// Sort by Date ("by the closest date of the current date")
result = (...)
return result;
}
}
然后你可以叫
Collections.sort(yourArrayListOfClassTest);
它将是非泛型的,但是是'Comparable'和'Comparator'都可以正常工作。 – Kayaman
实际上,在我的Java版本(1.4)中,我不能使用“
当然,您可以使用“比较器”。它只是一个非通用的。 – Kayaman
请查看 - http://www.cs.fsu.edu/~myers/cop3252/notes/examples/sorting/Sorting2Old.java – NageN
该版本多年来一直不受支持。 – sstan