首先,您的格式很 糟糕 ,请理清!
现在,使用lambda语法;转换匿名类:
final FilenameFilter filter = new FilenameFilter() { @Override public boolean accept(File dir, String name) { return false; }};
我们首先用等效的lambda替换单个方法的匿名类
accept(File dir, String name):
final FilenameFilter filter = (File dir, String name) -> { return false;};
但是我们可以做得更好,我们不需要定义类型-编译器可以解决这些问题:
final FilenameFilter filter = (dir, name) -> { return false;};
随着方法返回a,我们仍然可以做得更好
boolean。如果我们只有一条语句的结果为a,
boolean则可以跳过
return和大括号:
final FilenameFilter filter = (dir, name) -> false;
这可以是任何语句,例如:
final FilenameFilter filter = (dir, name) -> !dir.isDirectory() && name.toLowerCase().endsWith(".txt");
但是,该
FileAPI 很 旧,因此请勿使用。使用
nioAPI。自2011年Java
7以来就存在这种情况,因此实际上 没有任何 借口:
final Path p = Paths.get("/", "home", "text", "xyz.txt");final DirectoryStream.Filter<Path> f = path -> false;try (final DirectoryStream<Path> stream = Files.newDirectoryStream(p, f)) { stream.forEach(System.out::println);}
而事实上,你的例子已经建成一个具体方法
Files是需要一个水珠:
final Path p = Paths.get("/", "home", "text", "xyz.txt");try (final DirectoryStream<Path> stream = Files.newDirectoryStream(p, "*.txt")) { stream.forEach(System.out::println);}
或者,使用更现代的
Files.list:
final Path p = Paths.get("/", "home", "text", "xyz.txt");final PathMatcher filter = p.getFileSystem().getPathMatcher("glob:*.txt");try (final Stream<Path> stream = Files.list(p)) { stream.filter(filter::matches) .forEach(System.out::println);}
这
filter::matches是一个方法参考,因为该方法
PathMatcher.matches可用于实现功能接口,
Predicate<Path>因为它采用a
Path并返回a
boolean。
作为旁白:
f.list(new FilenameFilter() { @Override public boolean accept(File dir, String name) { name.endsWith(".txt"); return false; }});
这没有道理…
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)