开发中如果需要实现类似于SQL的右匹配,那么可以调用JDK8 API中的.stream().filter()方法,里面用lambda表达式实现
//需要过滤的数组
List<String> numbers = new ArrayList();
numbers.add(010101);
numbers.add(0102);
numbers.add(010103);
numbers.add(030101);
//需要以他为开头的字符串
String beginNumber = "0101";
//过滤
List<String> result = numbers.stream()
.filter(number->number.startWith(beginNumber))
.distinct()
.collect(Collectors.toList())
上述代码可以实现右匹配,但是如果numbers(代码块中的列表)中包含beginNumber那么他也会包含在内 如果不想让beginNumber的字符串出现,可以在里面加一行
/需要过滤的数组
List<String> numbers = new ArrayList();
numbers.add(010101);
numbers.add(0102);
numbers.add(010103);
numbers.add(030101);
//需要以他为开头的字符串
String beginNumber = "0101";
//过滤
List<String> result = numbers.stream()
.filter(number->number.startWith(beginNumber)) //获取以beginNumber开头的字符串
.filter(number->!number.equals(beginNumber)) //如果有排除以beginNumber自身
.distinct() //去重
.collect(Collectors.toList()) //再形成列表