gpt4 book ai didi

java - 如何在 Java 中实现 StringBuffer 类的比较器以便在 TreeSet 中使用?

转载 作者:行者123 更新时间:2023-11-29 10:15:47 25 4
gpt4 key购买 nike

我想为 StringBuffer 实现一个 Comparator,它比较 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);
}
}

最佳答案

内部类SbufferComparator必须是静态的,或者必须重构为顶级类。

否则,它需要构造一个封闭的对象实例:

ComparatorExample ce = new ComparatorExample();
SbufferComparator comparator = ce.new SbufferComparator();

将其保留为非静态内部类没有多大意义,因为它不使用其封闭类中的任何实例字段或方法。所以让它成为静态的或顶级的。

关于java - 如何在 Java 中实现 StringBuffer 类的比较器以便在 TreeSet 中使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18391374/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com