Приведенный ниже код позволяет нам запускать job
, при этом гарантируя, что одновременно может выполняться только одно задание, используя ReentrantLock
.
. Есть ли способ изменить этот код для запуска job.call()
асинхронно и возвращать MyConcurrentJobException
клиенту до запуска потока?
Мы пытались обернуть блок try / catch / finally в новый Thread
, но unlock
и lock
должныпроисходит в том же потоке, поэтому мы получаем IllegalMonitorException
??
final static Lock lock = new ReentrantLock();
public Object runJob(String desc, Callable job, boolean wait) {
logger.info("Acquiring lock");
if (!lock.tryLock()) {
throw new MyConcurrentJobException();
}
activeJob = new JobStatus(desc);
logger.info("Lock acquired");
try {
return job.call();
} catch (MarginServiceAssertionException e) {
throw e;
} catch (MarginServiceSystemException e) {
throw e;
} catch (Exception e) {
throw new MarginServiceSystemException(e);
} finally {
activeJob = null;
logger.info("Releasing lock");
lock.unlock();
logger.info("Lock released");
}
}