Ric*_*ick 15 java search list arraylist
我有点迷失方向让这个发生得最快.我有一大堆具有基本变量属性的对象(带有getter/setter),我需要在此列表中进行搜索,以查找列表中与给定参数匹配的对象
我已经找到了如何进行常规列表搜索但我需要,例如搜索为列表中的每个对象执行调用getName()的结果的值,并获取具有与我的输入匹配的结果的对象.
像下面的东西,第三个参数是方法调用的结果,第二个参数是我想要找到的.
   int index = Collections.binarySearch(myList, "value", getName());
任何建议表示赞赏
Tof*_*eer 10
public static int binarySearch(List list,T key,Comparator c)
所以你会做类似的事情:
class FooComparator
    implements Comparator<Foo>
{
    public int compare(T a, T b)
    {
        return (a.getName().compareTo(b.getName());
    }
}
int index = Collections.binarySearch(myList, "value", new FooComparator());
您需要先对课程列表进行排序(Collections.sort也需要Comaprator ...).
Nei*_*fey 10
如果你只是作为一次性操作需要找到其getName()是特定值的对象,那么可能没有多少魔法可能:循环遍历列表,在每个对象上调用getName(),对于那些匹配,将它们添加到您的结果列表中.
如果getName()是一个昂贵的操作,并且如果给定对象肯定不会返回匹配值,那么还有一些其他的先验方法可以解决,那么显然你可以在循环时构建这个'过滤'.
如果您经常需要为给定的getName()获取对象,则保留[getName() - > object - > matches of list]的结果的索引(例如,在HashMap中).您需要决定如何以及是否需要将此"索引"与实际列表保持同步.
另请参阅使用binarySearch()的其他命题,但要保持列表的维护.这样,插入比使用map和unsorted list更昂贵,但如果插入与查找相比不常见,那么它的优点是只需要维护一个结构.
我知道匿名的内部类不再是时尚了,但是当Java 8到来时,你可以创建这样的东西:
1.-创建一个搜索方法,迭代集合并传递一个对象,告诉您是否要返回对象.
2.-调用该方法并使用条件创建匿名内部类
3.-在单独的变量中获取新列表.
像这样的东西:
result = search( aList, new Matcher(){ public boolean matches( Some some ) { 
  if( some.name().equals("a")) { 
     return true;
  }
}});
这是一个有效的演示:
import java.util.*;
class LinearSearchDemo { 
  public static void main( String ... args ) { 
      List<Person> list = Arrays.asList(
                                  Person.create("Oscar", 0x20),
                                  Person.create("Reyes", 0x30),
                                  Person.create("Java", 0x10)
                          );
      List<Person> result = searchIn( list, 
              new Matcher<Person>() { 
                  public boolean matches( Person p ) { 
                      return p.getName().equals("Java");
              }});
      System.out.println( result );
      result = searchIn( list, 
              new Matcher<Person>() { 
                  public boolean matches( Person p ) { 
                      return p.getAge() > 16;
              }});
      System.out.println( result );
  }
  public static <T> List<T> searchIn( List<T> list , Matcher<T> m ) { 
      List<T> r = new ArrayList<T>();
      for( T t : list ) { 
          if( m.matches( t ) ) { 
              r.add( t );
          }
      }
      return r;
  }
}
class Person { 
  String name;
  int age;
  String getName(){ 
      return name;
  }
  int getAge() { 
      return age;
  }
  static Person create( String name, int age ) { 
      Person p = new Person();
      p.name = name;
      p.age = age;
      return p;
  }
  public String toString() { 
      return String.format("Person(%s,%s)", name, age );
  }    
}
interface Matcher<T> { 
  public boolean matches( T t );
}
输出:
[Person(Java,16)]
[Person(Oscar,32), Person(Reyes,48)]