
org.kurento.commons.TimeoutReentrantLock Maven / Gradle / Ivy
package org.kurento.commons;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.ReentrantLock;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TimeoutReentrantLock extends ReentrantLock {
private static final long serialVersionUID = 3260128010629476025L;
private static final Logger log = LoggerFactory.getLogger(TimeoutReentrantLock.class);
private long timeout;
private String name;
public TimeoutReentrantLock(long timeout, String name) {
this.timeout = timeout;
this.name = name;
}
public void tryLockTimeout(String method) {
// log.info("Thread {} trying to acquire lock {} in method {}", Thread
// .currentThread().getName(), name, method);
try {
if (!tryLock(timeout, TimeUnit.MILLISECONDS)) {
Thread ownerThread = getOwner();
throw new TimeoutRuntimeException("Timeout waiting " + timeout + " millis "
+ "to acquire lock " + name + ". The lock is held by thread " + ownerThread.getName());
}
} catch (InterruptedException e) {
throw new RuntimeException("InterruptedException while trying to acquire lock", e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy