本文整理匯總了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();
}
}
示例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
}
}
示例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;
}
示例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;
}
示例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;
}
示例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);
}
}
示例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;
}
}
示例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;
}
示例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;
}
}
示例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;
}