我的应用程序(Java5)分布在几个JVM中,这些JVM从共享存储中读取/写入文件(存储由Windows管理)。我希望将独占/共享锁用于文件写入/读取,如下所示:
FileOutputStream fos = null;
FileLock lock = null;
ObjectOutputStream oos = null;
try {
fos = new FileOutputStream(new File("//share/test.dat")); // HERE IT MAY THROW FileNotFoundException...
lock = fos.getChannel().lock(); // ... and I won't acquire a lock.
oos = new ObjectOutputStream(fos);
oos.writeObject(value);
return true;
} catch (Exception e) {
// Log it.
} finally {
// Close locks and I/O streams.
}问题:如果JVM1当前正在读取文件test.dat,而JVM2正在尝试写入同一个文件,那么在"new (“//share/test.dat”)“行中,将向JVM2抛出FileNotFoundException (”进程无法访问该文件,因为它正被另一个进程使用“)。这似乎是Catch22的情况:一方面,我想获得一个锁来获取I/O流;另一方面,我需要一个I/O流才能获得一个锁。正如我所看到的,RandomAccessFile也是如此。
有什么主意吗..。
发布于 2012-09-20 10:11:04
正如您从错误消息中看到的,Windows只是不允许您做您想要做的事情。如果考虑到Windows错误本身,可以将其视为锁定条件。因为打开和锁之间的定时窗口,您在这里会有一个同源的问题。窗户在某种程度上是在帮你的忙。就这一次。
https://stackoverflow.com/questions/12510348
复制相似问题