如果要查找所有以文本开头的条目(例如“ 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 inputSystem.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]由于
toto 的参数
subset(from,to)是排他的,因此您需要的东西显然会更大。在我的示例中,我只是添加了一个,
Character.MAX_VALUE但是您可能希望获得更好的上限。请注意,这取决于您的比较器,例如,它如何处理大小写差异等。
如果您想使用通配符进行过滤,例如 包含
该文本的所有文本(例如,
f将转换为
*f*),则必须遍历并检查所有条目。在这种情况下,使用排序集不会获得任何好处。
编辑:将示例更新为您的数据(也添加了我:))。



