當前位置: 首頁>>代碼示例>>Java>>正文


Java FileChannel.tryLock方法代碼示例

本文整理匯總了Java中java.nio.channels.FileChannel.tryLock方法的典型用法代碼示例。如果您正苦於以下問題:Java FileChannel.tryLock方法的具體用法?Java FileChannel.tryLock怎麽用?Java FileChannel.tryLock使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.nio.channels.FileChannel的用法示例。


在下文中一共展示了FileChannel.tryLock方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: zipFile

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
 * Compactar uma arquivo.
 * @param inputFile informar o arquivo a ser compactado.
 * @param zipFilePath informar o nome e caminho zip.
 * @param iZipFile se necessário, informar uma {@link IZipFile}.
 * @throws IOException
 */
public static void zipFile(File inputFile, String zipFilePath, IZipFile iZipFile) throws IOException {
    FileOutputStream fileOutputStream = new FileOutputStream(zipFilePath);
    ZipOutputStream zipOutputStream = new ZipOutputStream(fileOutputStream);
    ZipEntry zipEntry = new ZipEntry(inputFile.getName());
    zipOutputStream.putNextEntry(zipEntry);
    FileInputStream fileInputStream = new FileInputStream(inputFile);
    FileChannel fileChannel = fileInputStream.getChannel();
    FileLock fileLock = fileChannel.tryLock(0L, Long.MAX_VALUE, /*shared*/true);
    long sizeToZip = fileInputStream.available();
    long sizeCompacted = 0;
    try {
        byte[] buf = new byte[1024];
        int bytesRead;
        while ((bytesRead = fileInputStream.read(buf)) > 0) {
            sizeCompacted += bytesRead;
            zipOutputStream.write(buf, 0, bytesRead);
            if (iZipFile != null) iZipFile.progress(sizeToZip, sizeCompacted);
        }
    } finally {
        fileLock.release();
        zipOutputStream.closeEntry();
        zipOutputStream.close();
        fileOutputStream.close();
    }
}
 
開發者ID:brolam,項目名稱:OpenHomeAnalysis,代碼行數:33,代碼來源:OhaHelper.java

示例2: fileLock

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/** write lock file to prevent duplicate execution */
@SuppressWarnings("resource")
public static void fileLock() throws FileNotFoundException {
	lockFile = new File(Main.LOCK_FILE_LOCATION);

	FileChannel channel;
	channel = new RandomAccessFile(lockFile, "rw").getChannel();

	// try lock
	FileLock lock;
	try {
		lock = channel.tryLock();
		// already obtain lock in other JVM
		if (lock == null) {
			channel.close();
			System.exit(0);
		}
	} catch (IOException e) {
		// error handle
	}
}
 
開發者ID:Team-Sprout,項目名稱:Clipcon-Client,代碼行數:22,代碼來源:Main.java

示例3: getFileLock

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public boolean getFileLock() {

        boolean result = true;
        try {
            FileChannel fc = FileChannel.open(this.filePath, StandardOpenOption.READ, StandardOpenOption.WRITE,
                    StandardOpenOption.CREATE);
            fileLock = fc.tryLock();

            if (fileLock == null) {
                result = false;
            }
        }
        catch (Exception ex) {
            result = false;
        }

        return result;
    }
 
開發者ID:uavorg,項目名稱:uavstack,代碼行數:19,代碼來源:UpgradeProcessLock.java

示例4: getFileLockForWriting

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
 * Get file lock for writing too file
 * <p/>
 * TODO:this appears to have little effect on Windows Vista
 *
 * @param fileChannel
 * @param filePath
 * @return lock or null if locking is not supported
 * @throws IOException                                    if unable to get lock because already locked by another program
 * @throws java.nio.channels.OverlappingFileLockException if already locked by another thread in the same VM, we dont catch this
 *                                                        because indicates a programming error
 */
protected FileLock getFileLockForWriting(FileChannel fileChannel, String filePath) throws IOException {
    logger.finest("locking fileChannel for " + filePath);
    FileLock fileLock;
    try {
        fileLock = fileChannel.tryLock();
    }
    //Assumes locking is not supported on this platform so just returns null
    catch (IOException exception) {
        return null;
    }

    //Couldnt getFields lock because file is already locked by another application
    if (fileLock == null) {
        throw new IOException(ErrorMessage.GENERAL_WRITE_FAILED_FILE_LOCKED.getMsg(filePath));
    }
    return fileLock;
}
 
開發者ID:openaudible,項目名稱:openaudible,代碼行數:30,代碼來源:AbstractID3v2Tag.java

示例5: tryLockInternal

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
private static ProcessLock tryLockInternal(final String lockName, final String hash, final boolean writeMode) {
    synchronized (LOCK_MAP) {

        ConcurrentHashMap<Integer, ProcessLock> locks = LOCK_MAP.get(lockName);
        if (locks != null && !locks.isEmpty()) {
            Iterator<Map.Entry<Integer, ProcessLock>> itr = locks.entrySet().iterator();
            while (itr.hasNext()) {
                Map.Entry<Integer, ProcessLock> entry = itr.next();
                ProcessLock value = entry.getValue();
                if (value != null) {
                    if (!value.isValid()) {
                        itr.remove();
                    } else if (writeMode) {
                        return null;
                    } else if (value.mWriteMode) {
                        return null;
                    }
                } else {
                    itr.remove();
                }
            }
        }

        FileChannel channel = null;
        Closeable stream = null;
        try {
            File file = new File(
                    x.app().getDir(LOCK_FILE_DIR, Context.MODE_PRIVATE),
                    hash);
            if (file.exists() || file.createNewFile()) {

                if (writeMode) {
                    FileOutputStream out = new FileOutputStream(file, false);
                    channel = out.getChannel();
                    stream = out;
                } else {
                    FileInputStream in = new FileInputStream(file);
                    channel = in.getChannel();
                    stream = in;
                }
                if (channel != null) {
                    FileLock fileLock = channel.tryLock(0L, Long.MAX_VALUE, !writeMode);
                    if (isValid(fileLock)) {
                        ProcessLock result = new ProcessLock(lockName, file, fileLock, stream, writeMode);
                        LOCK_MAP.put(lockName, fileLock.hashCode(), result);
                        return result;
                    } else {
                        release(lockName, fileLock, file, stream);
                    }
                } else {
                    throw new IOException("can not get file channel:" + file.getAbsolutePath());
                }
            }
        } catch (Throwable ignored) {
            LogUtil.d("tryLock: " + lockName + ", " + ignored.getMessage());
            IOUtil.closeQuietly(stream);
            IOUtil.closeQuietly(channel);
        }
    }

    return null;
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:63,代碼來源:ProcessLock.java

示例6: obtainLock

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Override
public Lock obtainLock(@NonNull Directory dir, String lockName) throws IOException {
    if (!(dir instanceof RedisDirectory)) {
        throw new IllegalArgumentException("Expect argument of type [" + RedisDirectory.class.getName() + "]!");
    }
    Path lockFile = lockFileDirectory.resolve(lockName);
    try {
        Files.createFile(lockFile);
        log.debug("Lock file path = {}", lockFile.toFile().getAbsolutePath());
    } catch (IOException ignore) {
        //ignore
        log.debug("Lock file already exists!");
    }
    final Path realPath = lockFile.toRealPath();
    final FileTime creationTime = Files.readAttributes(realPath, BasicFileAttributes.class).creationTime();
    if (LOCK_HELD.add(realPath.toString())) {
        FileChannel fileChannel = null;
        FileLock lock = null;
        try {
            fileChannel = FileChannel.open(realPath, StandardOpenOption.CREATE, StandardOpenOption.WRITE);
            lock = fileChannel.tryLock();
            if (lock != null) {
                return new RedisLock(lock, fileChannel, realPath, creationTime);
            } else {
                throw new LockObtainFailedException("Lock held by another program: " + realPath);
            }
        } finally {
            if (lock == null) {
                IOUtils.closeQuietly(fileChannel);
                clearLockHeld(realPath);
            }
        }
    } else {
        throw new LockObtainFailedException("Lock held by this virtual machine: " + realPath);
    }
}
 
開發者ID:shijiebei2009,項目名稱:RedisDirectory,代碼行數:37,代碼來源:RedisLockFactory.java

示例7: getLock

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@SuppressWarnings("resource")
public static synchronized FileLock getLock(File file)
{
	System.out.println("Attempting to acquire file lock for " + file.getAbsolutePath());
	FileChannel channel = null;
	try
	{
		channel = new RandomAccessFile(file, "rw").getChannel();
		return channel.tryLock();
	}
	catch (IOException | OverlappingFileLockException e)
	{
		System.err.println("Failed to lock channel");
		e.printStackTrace();

		if (channel != null)
		{
			try
			{
				channel.close();
			}
			catch (IOException e1)
			{
				System.err.println("Failed to close lock channel");
				e1.printStackTrace();
			}
		}
		return null;
	}
}
 
開發者ID:PolyphasicDevTeam,項目名稱:NoMoreOversleeps,代碼行數:31,代碼來源:LockingHelper.java

示例8: getFileLockForWriting

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
 * Get file lock for writing too file
 * <p/>
 * TODO:this appears to have little effect on Windows Vista
 *
 * @param fileChannel
 * @param filePath
 * @return lock or null if locking is not supported
 * @throws IOException                                    if unable to get lock because already locked by another program
 * @throws java.nio.channels.OverlappingFileLockException if already locked by another thread in the same VM, we dont catch this
 *                                                        because indicates a programming error
 */
protected FileLock getFileLockForWriting(FileChannel fileChannel, String filePath) throws IOException
{
    logger.finest("locking fileChannel for " + filePath);
    FileLock fileLock;
    try
    {
        fileLock = fileChannel.tryLock();
    }
    //Assumes locking is not supported on this platform so just returns null
    catch (IOException exception)
    {
        return null;
    }
    //#129 Workaround for https://bugs.openjdk.java.net/browse/JDK-8025619
    catch (Error error)
    {
        return null;
    }

    //Couldnt getFields lock because file is already locked by another application
    if (fileLock == null)
    {
        throw new IOException(ErrorMessage.GENERAL_WRITE_FAILED_FILE_LOCKED.getMsg(filePath));
    }
    return fileLock;
}
 
開發者ID:GlennioTech,項目名稱:MetadataEditor,代碼行數:39,代碼來源:AbstractID3v2Tag.java

示例9: tryAcquireLock

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
private FileLock tryAcquireLock(final FileChannel channel) throws IOException {
    try {
        return channel.tryLock();
    } catch (OverlappingFileLockException e) {
        return null;
    }
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:8,代碼來源:StateDirectory.java

示例10: setup

import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
 * Setup all the files and directories needed for the tests
 *
 * @return writable directory created that needs to be deleted when done
 * @throws RuntimeException
 */
private static File setup() throws RuntimeException {
    // First do some setup in the temporary directory (using same logic as
    // FileHandler for %t pattern)
    String tmpDir = System.getProperty("java.io.tmpdir"); // i.e. %t
    if (tmpDir == null) {
        tmpDir = System.getProperty("user.home");
    }
    File tmpOrHomeDir = new File(tmpDir);
    // Create a writable directory here (%t/writable-lockfile-dir)
    File writableDir = new File(tmpOrHomeDir, WRITABLE_DIR);
    if (!createFile(writableDir, true)) {
        throw new RuntimeException("Test setup failed: unable to create"
                + " writable working directory "
                + writableDir.getAbsolutePath() );
    }

    // try to determine whether file locking is supported
    final String uniqueFileName = UUID.randomUUID().toString()+".lck";
    try {
        FileChannel fc = FileChannel.open(Paths.get(writableDir.getAbsolutePath(),
                uniqueFileName),
                StandardOpenOption.CREATE_NEW, StandardOpenOption.APPEND,
                StandardOpenOption.DELETE_ON_CLOSE);
        try {
            fc.tryLock();
        } catch(IOException x) {
            supportsLocking = false;
        } finally {
            fc.close();
        }
    } catch (IOException t) {
        // should not happen
        System.err.println("Failed to create new file " + uniqueFileName +
                " in " + writableDir.getAbsolutePath());
        throw new RuntimeException("Test setup failed: unable to run test", t);
    }
    return writableDir;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:45,代碼來源:CheckZombieLockTest.java


注:本文中的java.nio.channels.FileChannel.tryLock方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。