今天我有一个不区分大小写的排序Set
,如:
Set<String> set = new TreeSet<>(String.CASE_INSENSITIVE_ORDER);
set.add("foo");
set.add("FOO");
set.add("bar");
System.out.println(set.toString());
这个输出是:
[bar, foo]
但我真正想要的是:
[bar, FOO, foo]
也就是说,我希望集合的排序不区分大小写,但我希望能够在不同情况下使用相同的字符串(如“foo”和“FOO”)集合,没有丢弃最后一个。
我知道我可以对List
进行排序,但就我而言,我需要Set
。
在Java中有这种简洁的方法吗?
答案 0 :(得分:7)
您可能希望使用一个不区分大小写的比较器,然后使用区分大小写的顺序作为决胜局。
类似于:
Set<String> set = new TreeSet<>((a, b) -> {
int insensitive = String.CASE_INSENSITIVE_ORDER.compare(a, b);
return insensitive==0 ? a.compareTo(b) : insensitive;
});