如果要查找以文本开头的所有条目(例如“f”),可以使用该subSet(from, to)
方法,如下所示:
SortedSet<String> s = new TreeSet<String>(new Comparator<String>() {
public int compare( String s1, String s2 ) {
return s1.compareToIgnoreCase( s2 );
}
});
s.add( "Erich" );
s.add( "Erica" );
s.add( "Erin" );
s.add( "Dave" );
s.add( "Thomas" );
SortedSet<String> result = s.subSet( "e", "e" + Character.MAX_VALUE ); //"e" represents the user input
System.out.println(result);//prints [Erica, Erich, Erin]
result = s.subSet( "Eric", "Eric" + Character.MAX_VALUE );
System.out.println(result); //prints [Erica, Erich]
result = s.subSet( "Erich", "Erich" + Character.MAX_VALUE );
System.out.println(result); //prints [Erich]
由于to
参数 tosubset(from, to)
是独占的,因此您需要明显更大的参数。在我的示例中,我只是添加Character.MAX_VALUE
了一些内容,但您可能希望获得更好的上限。请注意,这取决于您的比较器,例如它如何处理大小写差异等。
如果您想使用通配符进行过滤,例如所有包含该文本的文本(例如f
将转换为*f*
),则无论如何您都必须遍历并检查所有条目。在这种情况下,使用排序集不会获得任何优势。
编辑:将示例更新为您的数据(也添加我:))。