【发布时间】:2015-06-11 20:55:00
【问题描述】:
我正在创建文件和文件夹树。我正在重写多线程。我看到的唯一弱点是创建文件夹时。现在它一一进行(深入)。在我写下文件之前,我检查路径是否存在。如果没有,我会使用 mkdirs 来创建所有缺失的内容。
public void checkDir(String relativePath) {
File file = new File(homePath + relativePath);
if (!file.exists()) {
if (file.mkdirs()) {
log.info("Directory: " + homePath + relativePath + " is created!");
} else {
log.error("Failed to create directory: " + homePath + relativePath + " !");
}
}
}
我有一个问题,当我使用两个线程时会发生什么。一个有路径 A/B/C,另一个有 A/B/D。假设我只有 A 文件夹,但没有 B。所以他们俩都会检查该路径是否不存在并想要创建它。所以其中一个可能会失败,因为另一个会更快。那么我该如何管理呢?
- 我正在考虑删除存在条件并使其失败,但我无法捕获任何 AlreadyExists 异常..
- 先创建目录树(但我认为会有更好的方法?)
- 将目录创建作为关键部分并使其按顺序进行 - 不知道如何在春季执行此操作,但无论如何热确定它是必要的并且不会过多地减慢进程。
也许是我想太多了,但理论上这种情况可能会发生。目前我使用常规线程,但我想为此使用 spring TaskExecutor。它自己处理关键部分,但这不是共享变量或任何东西,而且路径不同,所以我认为它不会识别它。
感谢您的建议。
【问题讨论】:
-
如果更快,我不会失败 java 会意识到该目录存在并且不会成功。
-
既然这看起来对性能不重要,为什么不直接同步方法呢?
-
您应该考虑 Kári 的回答。原子不会自动暗示操作是同步的。
-
请注意,连接字符串以创建文件路径容易出错且脆弱。好像代表文件首先是字符串。我建议您从一开始就重写代码以使用
Path,并在Path上使用relativize和resolve等方法来处理这些路径。最后,使用Files进行操作,因为它的错误处理要好得多。 TL;DR 不要使用String来表示类型化的数据,也不要使用FileAPI。
标签: java multithreading spring mkdirs