问:谈谈你对 FileLock 的理解认识?
答:FileLock 用来表示文件区域锁定标记,其仅是一个锁操作的辅助类,可以通过 FileChannel.lock()
或者 FileChannel.tryLock()
等方法获取文件锁,一旦获取锁则持续有效,直到被 release()
或 JVM 退出,可以通过 FileLock.isValid()
方法来检测文件锁的有效性。
文件锁要么是共享锁,要么是独占锁。共享锁可以阻止并发运行的程序获取独占锁,但是允许程序继续获取共享锁;独占锁可以阻止并发运行的程序获取其他任意类型锁。我们可以通过 FileLock.isShared()
方法来检测锁的模式。特别注意,有些平台不支持文件共享锁,这种平台上共享锁会变成独占锁。
FileLock 文件锁是以 JVM 进程为单位的(OS 特性相关),其不适用于控制同一个 JVM 内多个线程对文件的访问(会抛出 OverlappingFileLockException
异常),但 FileLock 对象自身相关的操作在多线程中是安全的。单个 JVM 在某个文件上所保持的锁是不重叠的(即在进程级别不会重复获取锁),可以使用 FileLock.overlaps()
方法测试是否会锁定重叠。
要锁定一个文件,可以调用 FileChannel
类的下列方法获取文件锁:
FileChannel channel = FileChannel.open(path);
//阻塞直至可获得锁。
FileLock lock = channel.lock();
//立即返回,要么返回锁,要么在锁不可获得的情况下返回null。
FileLock lock = channel.tryLock();
//如果shared为false,则锁定文件的目的是独占锁。
//如果shared为true,则是一个共享锁,允许多个进程从文件中读入,并阻止任何进程获得独占的锁。
FileLock.isShared();
//如果锁定了文件的尾部,而这个文件的长度随后增长超过了锁定的部分,那么增长出来的额外区域是未锁定的。
//想要锁定所有的字节可以使用 Long.MAX_VALUE 来表示 size。
FileLock lock = channel.lock(start, size, shared);
FileLock lock = channel.tryLock(start, size, shared);
特别注意,共享锁指的是允许多个并发进行文件的读取操作,独占锁指的是只允许一个进行文件的读/写操作。对于使用 FileLock 文件锁时务必注意文件的读写权限。
本文參考自 多进程文件锁 FileLock 相关基础解析