Сонар. Используйте try-with-resources или закройте этот «поток» в предложении «finally» в потоке java8 - PullRequest
0 голосов
/ 14 февраля 2019

Sonar Qube дает мне следующую ошибку

Используйте try-with-resources или закройте этот «Поток» в предложении «finally»

List<Path> paths = find(Paths.get(nasProps.getUpstreamOutputDirectory() + File.separator + inputSource.concat("_").concat(contentGroup).concat("_").concat(parentId)),
                MAX_VALUE, (filePath, fileAttr) -> fileAttr.isRegularFile() && filePath.getFileName().toString().matches(".*\\." + extTxt))
                .collect(toList());
paths.stream().forEach(path -> textFileQueue.add(path));

Я не очень понимаюjava8.не могли бы вы помочь мне закрыть поток

1 Ответ

0 голосов
/ 14 февраля 2019

Предполагая, что find здесь Files.find, вам следует использовать

final Path startPath = Paths.get(nasProps.getUpstreamOutputDirectory() +
        File.separator +
        inputSource.concat("_").concat(contentGroup).concat("_").concat(parentId));
BiPredicate<Path, BasicFileAttributes> matcher = (filePath, fileAttr) ->
        fileAttr.isRegularFile() && filePath.getFileName().toString().matches(".*\\." + extTxt);

try (Stream<Path> pathStream = Files.find(startPath, Integer.MAX_VALUE, matcher)) {
    pathStream.forEach(path -> textFileQueue.add(path));
} catch (IOException e) {
    e.printStackTrace(); // handle or add to method calling this block
}

Причина, по которой sonarqube предупреждает здесь, упоминается в примечании API связанного документа:

Этот метод должен использоваться внутри оператора try-with-resources или аналогичной структуры управления, чтобы гарантировать, что открытые каталоги потока будут закрыты сразу после выполнения операций потоказавершено.

...