📄 niolockfile.java
字号:
/* Copyright (c) 2001-2005, The HSQL Development Group
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* Neither the name of the HSQL Development Group nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG,
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.hsqldb.persist;import java.nio.channels.FileChannel;import java.nio.channels.FileLock;/** * A LockFile variant that capitalizes upon the * availability of {@link java.nio.channels.FileLock FileLock}. * * @author boucherb@users * @version 1.7.2 * @since 1.7.2 * */final class NIOLockFile extends LockFile { // From the java.nio.channels.FileLock API docs: // // Some network filesystems do not implement file locks on regions // that extend past a certain position, often 2**30 or 2**31. // In general, great care should be taken when locking files that // reside on network filesystems. static final long MAX_NFS_LOCK_REGION = (1L << 30); static final long MIN_LOCK_REGION = MAGIC.length + 8; /** * A <code>FileChannel</code> object obtained from the super * <code>raf</code> attribute. <p> * * The <code>fc</code> attribute is used to obtain this object's * {@link #fl FileLock} attribute. */ private FileChannel fc; /** * The <code>FileLock</code> object used to lock this object's * lock file. */ private FileLock fl; /** * Tries to obtain a valid NIO lock upon this object's lock file using * this object's {@link #fl FileLock} attribute. * * @return true if a valid lock is obtained, else false. * @throws Exception if an error occurs while attempting to obtain the lock * */ protected boolean lockImpl() throws Exception { boolean isValid; if (fl != null && fl.isValid()) { return true; } trace("lockImpl(): fc = raf.getChannel()"); fc = raf.getChannel(); trace("lockImpl(): fl = fc.tryLock()"); fl = null; try { fl = fc.tryLock(0, MIN_LOCK_REGION, false); trace("lockImpl(): fl = " + fl); } catch (Exception e) { // This will not work with a localized JVM /* if (-1 == e.toString().indexOf("No locks available")) { throw e; } else { trace(e.toString()); } */ trace(e.toString()); }// In an ideal world, maybe?:// try {// fl = fc.tryLock();//// trace("lockImpl(): fl = " + fl);// } catch (Exception e) {// trace(e.toString());//// try {// fl = fc.tryLock(0, MAX_NFS_LOCK_REGION, false);//// trace("lockImpl(): fl = " + fl);// trace("Warning: possibly attempting to lock on NFS");// } catch (Exception e2) {// trace(e2.toString());//// try {// fl = fc.tryLock(0, MIN_LOCK_REGION, false);//// trace("lockImpl(): fl = " + fl);// trace("Warning: backed off to min lock region");// trace("Warning: lock file may be unusable on reuse");// } catch (Exception e3) {// trace(e3.toString());// }// }// } trace("lockImpl(): f.deleteOnExit()"); f.deleteOnExit(); isValid = fl != null && fl.isValid(); trace("lockImpl():isValid(): " + isValid); return isValid; } /** * Tries to release any valid lock held upon this object's lock file using * this object's {@link #fl FileLock} attribute. * * @return true if a valid lock is released, else false * @throws Exception if na error occurs while attempting to release the lock */ protected boolean releaseImpl() throws Exception { // PRE: we know that this method is only called // if isLocked() is true. trace("releaseImpl(): fl = " + fl); if (fl != null) { trace("releaseImpl(): fl.release()"); fl.release(); trace("tryRelease(): fl = " + fl); fl = null; } trace("releaseImpl(): fc = " + fc); if (fc != null) { trace("releaseImpl(): fc.close()"); fc.close(); fc = null; } // CHECKME: // possibly overcomes some regarding full and // true release of FileLock and maybe related // NIO resources? // System.gc(); return true; } /** * Retrieves whether this object's {@link #fl FileLock} attribute represents * a valid lock upon this object's lock file. * * @return true if this object's {@link #fl FileLock} attribute is valid, * else false */ public boolean isValid() { return super.isValid() && (fl != null && fl.isValid()); } /** * Retrieves the String value: "fl =" + fl * @return the String value: "fl =" + fl */ protected String toStringImpl() { return "fl =" + fl; }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -