使用自定义属性

时间:2017-05-26 10:22:29

标签: java android sorting arraylist

我有按顺序排列服装尺寸的数组列表:" L"," M"," XL"," XS", " S"," XXL"我需要按照以下顺序排列:" XS"," S"," M"," L",&#34 ; XL"," XXL"。

Collections.sort(arrayList);
如果我有这个样本的数组,

将完成这项工作:" 38"," 36"," 34"," 40" ,但不是与上述相关。因此我决定使用for循环和交换数组列表中的项目并将它们放在正确的位置,但由于数组列表的大小是动态更改的,我无法确定应该指定哪个位置。

我很确定这可能不是正确的方法,但我们都愿意接受如何解决这个问题的建议。

现在这里是代码的一部分:

// Sample clothing sizes
    List<String> availableSizes = new ArrayList<>(tempSizes);
    // Sorting array, only works for "34", "38", "36" and etc
    Collections.sort(availableSizes);

    if (availableSizes.size() > 0) {
        for (int i = 0; i < availableSizes.size(); i++) {
            if (availableSizes.get(i).equals("XS")) {
                Collections.swap(availableSizes, i, 0);
            } else if (availableSizes.get(i).equals("S")) {
                Collections.swap(availableSizes, i, 1);
            } else if (availableSizes.get(i).equals("M")) {
                Collections.swap(availableSizes, i, 2);
            } else if (availableSizes.get(i).equals("L")) {
                Collections.swap(availableSizes, i, 3);
            } else if (availableSizes.get(i).equals("XL")) {
                Collections.swap(availableSizes, i, 4);
            } else if (availableSizes.get(i).equals("XXL")) {
                Collections.swap(availableSizes, i, 5);
            }
        }
    }

显然,如果数组大小小于5,我将收到错误。

1 个答案:

答案 0 :(得分:7)

在某些列表或地图中按正确顺序存储大小(以提高性能)。然后你可以创建自己的比较器,它将检查该列表/地图中搜索大小的位置,并将其与其他元素的位置进行比较。您需要做的就是比较这些位置。

类似的东西:

private static Comparator<String> sizeComparator = new Comparator<String>() {

    private Map<String,Integer> sizes = new HashMap<>();
    {
        int i=0;
        for (String size : new String[]{"XS", "S", "M", "L", "XL", "XXL"}){
            sizes.put(size,i++);
        }
    }

    @Override
    public int compare(String o1, String o2) {
        return Integer.compare(sizes.get(o1),sizes.get(o2));
    }

};

用法:

List<String> list = Arrays.asList("L", "M", "XL", "XS", "S", "XXL" );
System.out.println(list);
list.sort(sizeComparator);
System.out.println(list);

输出:

[L, M, XL, XS, S, XXL] //before sorting
[XS, S, M, L, XL, XXL] //after sorting