FileChannel文件锁

来源:互联网 发布:apache hadoop yarn 编辑:程序博客网 时间:2024/06/05 16:51
package com.itbuluoge.nio;import java.io.FileOutputStream;import java.nio.channels.FileLock;public class FileChannel {/** * @param args * @throws Exception  */public static void main(String[] args) throws Exception {// TODO Auto-generated method stubFileOutputStream fout=new FileOutputStream("file.txt");FileLock fl=fout.getChannel().tryLock();if(fl!=null){System.out.println("locking.......");Thread.sleep(10000);fl.release();System.out.println("release lock");}else{System.out.println("file is locking!");}fout.close();}}

文件锁,用于在读取FileChannel的时候,获得整个文件的锁,防止其他线程或者进程对文件进行同步操作。

其中getChannel().tryLock()是非阻塞的,也就是说,在发现文件被锁住的时候,直接返回null,如果没有锁住,直接返回该文件的文件锁。

而getChannel().lock()是阻塞的,在文件有所的情况下,会保持阻塞,直到获得该锁为止。

0 0
原创粉丝点击