我想为 StringBuffer 实现一个比较器,它比较 StringBuffer 并相应地添加到 TreeSet。这纯粹是为了学习目的。我知道在 Hasable 集合中有一个可变对象是个坏主意。但这里的目的是如何为Java现有的StringBuffer类实现比较器并使用它来创建一个TreeSet。我当前的代码如下。代码无法编译。请帮帮我。谢谢
public class ComparatorExample {
public class SbufferComparator implements Comparator<StringBuffer> {
@Override
public int compare(StringBuffer s1, StringBuffer s2) {
return s1.toString().compareTo(s2.toString());
}
}
public static void main(String[] args) {
StringBuffer one = new StringBuffer("one");
StringBuffer two = new StringBuffer("two");
StringBuffer three = new StringBuffer("three");
Set<StringBuffer> sb=new TreeSet<StringBuffer>(new SbufferComparator());
sb.add(one);
sb.add(two);
sb.add(three);
System.out.println("set before change: "+ sb);
one.append("onemore");
System.out.println("set After change: "+ sb);
}
}