下面是我用来寻找palindrome(回文)的代码:
public static void main(String[] args) {
Set<String> set = Sets.newHashSet("refer", "mom", "father", "dad");
Collection<String> palinSet = Collections2.filter(set,
new Predicate<String>() {
@Override
public boolean apply(String input) {
return new StringBuilder(input).reverse().toString()
.equals(input);
}
});
Iterator<String> i = palinSet.iterator();
while (i.hasNext()) {
System.out.println(i.next());
}
}
在这里面用了一个匿名内部类:实现了Predicate接口。最开始我疑惑地是Predicate接口有两个方法:
1)boolean apply(@Nullable T input)
2)boolean equals(@Nullable Object object)
但是匿名内部类只实现了apply方法,这不符合要实现接口中所有方法的要求。
解释:Object是所有类的父类,而且Object中实现了equals方法。因此匿名内部类中已经继承了equals方法,不需要再次实现。
本文介绍了一种使用Java编程语言寻找回文字符串的方法。通过匿名内部类实现Predicate接口的apply方法来判断一个字符串是否为回文,并展示了如何过滤集合中的回文元素。
4707

被折叠的 条评论
为什么被折叠?



