如何按照我想要的方式对这个 ArrayList 进行排序?

2022-09-01 05:40:59

下面是一个简单的数组列表排序程序:

ArrayList<String> list = new ArrayList<String>();

list.add("1_Update");
list.add("11_Add");
list.add("12_Delete");
list.add("2_Create");

Collections.sort(list);
for (String str : list) {
  System.out.println(str.toString());
}

我期望这个程序的输出是:

1_Update
2_Create
11_Add
12_Delete

但是当我运行这个程序时,我得到的输出是:

11_Add
12_Delete
1_Update
2_Create

为什么会这样,我如何让 ArrayList 按照预期输出中所示进行排序?


答案 1

您可以编写一个自定义比较器:

Collections.sort(list, new Comparator<String>() {
    public int compare(String a, String b) {
        return Integer.signum(fixString(a) - fixString(b));
    }
    private int fixString(String in) {
        return Integer.parseInt(in.substring(0, in.indexOf('_')));
    }
});

答案 2

将此类型的数据作为字符串进行排序时,它会比较字符本身,包括数字。例如,所有以“1”开头的字符串最终都会在一起。所以订单最终与此类似...

1 10 100 2 20 200

排序永远不会“意识到”您正在为字符串的子集分配含义,例如字符串前面的可变长度数字。将数字排序为字符串时,在左侧填充以尽可能多地填充以覆盖最大数字可能会有所帮助,但是当您不控制数据时,它并不能真正解决问题,如您的示例所示。在这种情况下,排序将是...

001 002 010 020 100 200


推荐