Android开发

Java 多进程文件锁 FileLock

2018-08-24  本文已影响0人  Little丶Jerry
问:谈谈你对 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 相关基础解析

上一篇 下一篇

猜你喜欢

热点阅读