gpt4 book ai didi

java - 检索目录中的文件名时出现问题

转载 作者:行者123 更新时间:2023-12-02 09:41:18 24 4
gpt4 key购买 nike

我有以下方法来检索日志目录中 logback 生成的日志文件的名称。前 9 行确定日志记录目录:

    private List<String> getLogFileNames() {
List<String> logFileNames = new ArrayList<>();

ch.qos.logback.classic.Logger rootLogger = ((ch.qos.logback.classic.Logger) LOGGER).getLoggerContext().getLogger("root");

Path logDir;

Appender<ILoggingEvent> appender = rootLogger.getAppender("file");
if (appender == null) {
logDir = Paths.get(System.getProperty("user.dir"), "../logs");
} else {
RollingFileAppender<?> rollingFileAppender = (RollingFileAppender<?>) appender;
logDir = Paths.get(rollingFileAppender.getFile()).getParent();
}

try {
Files.list(logDir).forEach(log -> logFileNames.add(log.toFile().getName()));
} catch (IOException e) {
throw new IllegalStateException(e);
}

return logFileNames;
}

有时会抛出以下异常: java.nio.file.FileSystemException: ... : 打开文件太多

我怀疑该异常是在 Files.list(logDir).forEach() 语句中引发的。不知何故,在这段代码中,文件被打开但从未关闭。我应该如何解决这个问题?我可以使用 foreach 语句还是应该使用类似以下内容的语句:

try(Stream<Path> stream = Files.walk(logDir)) {
// Code to extract the filename
}
catch(UncheckedIOException ex) {
throw ex.getCause();
}

最佳答案

关于java - 检索目录中的文件名时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57047680/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com