com.hazelcast.core.ILock Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2016, Hazelcast, Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.hazelcast.core;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
/**
* Distributed implementation of {@link Lock}.
*
* Example
*
* Lock mylock = Hazelcast.getLock(mylockobject); mylock.lock();
* try {
* // do something
* } finally {
* mylock.unlock();
* }
* //Lock on Map
* IMap map = Hazelcast.getMap("customers"); map.lock("1");
* try {
* // do something
* } finally {
* map.unlock("1"); }
*
*
* @see Lock
*/
public interface ILock extends Lock, DistributedObject {
/**
* Returns the lock object, the key for this lock instance.
*
* @return lock object.
* @deprecated use {@link #getName()} instead.
*/
@Deprecated
Object getKey();
/**
* {@inheritDoc}
*/
void lock();
/**
* {@inheritDoc}
*/
boolean tryLock();
/**
* {@inheritDoc}
*/
boolean tryLock(long time, TimeUnit unit) throws InterruptedException;
/**
* Tries to acquire the lock for the specified lease time.
* After lease time, the lock will be released.
*
* If the lock is not available, then
* the current thread becomes disabled for thread scheduling
* purposes and lies dormant until one of two things happens:
*
* - the lock is acquired by the current thread, or
*
- the specified waiting time elapses.
*
*
*
* @param time maximum time to wait for the lock.
* @param unit time unit of the time argument.
* @param leaseTime time to wait before releasing the lock.
* @param leaseUnit unit of time to specify lease time.
* @return true if the lock was acquired and false
* if the waiting time elapsed before the lock was acquired.
*/
boolean tryLock(long time, TimeUnit unit, long leaseTime, TimeUnit leaseUnit) throws InterruptedException;
/**
* Releases the lock.
*/
void unlock();
/**
* Acquires the lock for the specified lease time.
* After lease time, lock will be released..
*
* If the lock is not available then
* the current thread becomes disabled for thread scheduling
* purposes and lies dormant until the lock has been acquired.
*
*
* @param leaseTime time to wait before releasing the lock.
* @param timeUnit unit of time for the lease time.
*
* @throws IllegalMonitorStateException if the current thread does not
* hold this lock
*/
void lock(long leaseTime, TimeUnit timeUnit);
/**
* Releases the lock regardless of the lock owner.
* It always successfully unlocks, never blocks, and returns immediately.
*/
void forceUnlock();
/**
* This method is not implemented! Use {@link #newCondition(String)} instead.
*
* @throws UnsupportedOperationException
*/
Condition newCondition();
/**
* Returns a new {@link ICondition} instance that is bound to this
* {@code ILock} instance with given name.
*
* Before waiting on the condition the lock must be held by the
* current thread.
* A call to {@link ICondition#await()} will atomically release the lock
* before waiting and re-acquire the lock before the wait returns.
*
* @param name identifier of the new condition instance
* @return A new {@link ICondition} instance for this {@code ILock} instance
* @throws java.lang.NullPointerException if name is null.
*/
ICondition newCondition(String name);
/**
* Returns whether this lock is locked or not.
*
* @return {@code true} if this lock is locked, {@code false} otherwise.
*/
boolean isLocked();
/**
* Returns whether this lock is locked by current thread or not.
*
* @return {@code true} if this lock is locked by current thread, {@code false} otherwise.
*/
boolean isLockedByCurrentThread();
/**
* Returns re-entrant lock hold count, regardless of lock ownership.
*
* @return the lock hold count.
*/
int getLockCount();
/**
* Returns remaining lease time in milliseconds.
* If the lock is not locked then -1 will be returned.
*
* @return remaining lease time in milliseconds.
*/
long getRemainingLeaseTime();
}