从列表中删除并进行日期比较

时间:2019-02-20 10:53:59

标签: java list iterator refactoring

我必须删除param.getFromDateTime之前和params.getToDateTime之后的所有对象。我是这样的:

for (ListIterator<Doc> iterator = doc.listIterator(); iterator.hasNext(); ) {
    while(iterator.hasNext()){
            if(param.getFromDateTime() != null
              && doc.get(iterator.nextIndex()).getDate().before(params.getFromTime())) {
                iterator.remove();
            }
            if(params.getToDateTime() != null
              && doc.get(iterator.nextIndex()).getDate().after(params.getToDateTime())) {
                iterator.remove();
           }
    }
}

我可以做得更好,更清晰吗?

3 个答案:

答案 0 :(得分:3)

您不需要两个循环,也不需要ListIterator
请注意,这两个条件可能是正确的,但是无论如何您都只希望删除一个元素,因为两次调用remove()会引发异常。
您还可以直接从迭代的date对象中提取Doc,以使其更加清晰:

for (Iterator<Doc> iterator = doc.iterator(); iterator.hasNext(); ) {
      Date date = iterator.next().getDate();

      if( (param.getFromDateTime() != null && date.before(params.getFromTime())) 
          || (params.getToDateTime() != null && date.after(params.getToDateTime()))) {
        iterator.remove();
      }

}

答案 1 :(得分:2)

带有流api的java-8替代:

List<Doc> docs = ...;
Stream<Doc> stream = docs.stream();
LocalDateTime fromDateTime = param.getFromDateTime();
LocalDateTime toDateTime = param.getToDateTime();
if (fromDateTime != null){
    stream = stream.filter(d -> !d.getDate().before(fromDateTime);
}
if (toDateTime != null){
    stream = stream.filter(d -> !d.getDate().after(toDateTime);
}
docs = stream.collect(Collectors.toList());

答案 2 :(得分:2)

在使用Java 8的情况下,您可能希望使用List.removeIf

List<Doc> docs = generateSomeValues(); // this ist just an imaginary filling of the list
// check if the params are not null and remove dates that are not in the given interval
docs.removeIf(doc ->
    (params.getFromTime() != null && doc.getDate().before(params.getFromTime()))
    || (params.getToDateTime() != null && doc.getDate().after(params.getToDateTime()))
);