美文网首页Android开发
Java 多进程文件锁 FileLock

Java 多进程文件锁 FileLock

作者: Little丶Jerry | 来源:发表于2018-08-24 10:21 被阅读0次
问:谈谈你对 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 相关基础解析

相关文章

  • Java 多进程文件锁 FileLock

    问:谈谈你对 FileLock 的理解认识? 答:FileLock 用来表示文件区域锁定标记,其仅是一个锁操作的辅...

  • JAVA 文件锁 FileLock

    概述 FileLock是java 1.4 版本后出现的一个类,它可以通过对一个可写文件(w)加锁,保证同时只有一个...

  • JAVA NIO 文件锁FileLock

    文件锁可以是shared(共享锁)或者exclusive(排他锁)。不是所有的平台都以同一种方式实现文件锁,不同的...

  • java nio - 2 文件加锁

    文件锁 FileLock Jdk 1.4 引入文件加锁机制,它允许我们同步访问某个作为共享资源的文件。不过,竞争同...

  • 进程学习三

    进程进阶 1.进程锁 这里的进程锁与线程锁、互斥量、读写锁和自旋锁不同,它是通过记录一个PID文件,避免两个进程同...

  • APUE读书笔记-13守护进程(5)

    6、守护进程遵循的一些标准 Unix上面的守护进程,一般会遵循如下的通用标准: 如果守护进程使用锁文件,那么锁文件...

  • android中解读ANR产生的trace文件

    1.java进程的trace文件解析2.native进程的trace文件解析

  • 数据机房的几种“锁”

    此锁非彼锁,今天介绍几种数据锁。 1、文件锁 当多个进程可能会对同样的数据执行操作时,这些进程需要保证其它进...

  • PHP 文件锁与进程锁

    鉴于前面介绍了swoole,就借用swoole的服务器/客户端与多进程机制对锁进行说明.这里只针对PHP的锁机制进...

  • 简单定位多线程问题

    使用jps 可以列出程序中的Java进程名字 和pid jstack -l pid 可以查看进程锁信息

网友评论

    本文标题:Java 多进程文件锁 FileLock

    本文链接:https://www.haomeiwen.com/subject/sdqbiftx.html