私のアプリケーションは、Java 6 update 30 を使用して Weblogic 10.3.5 にデプロイされています。このコード行の実行中に、次のエラーが発生しました。
lock.readLock().lock();
try {
holder = cache.get(configName);
// If it exists in the cache, return it
if (holder != null)
return holder;
} finally {
lock.readLock().unlock();
}
クラスのロード中にロックが初期化されている間:
private final ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
キャッシュは次のとおりです。
private Map<String, ConfigurationHolder> cache = new HashMap<String,ConfigurationHolder>();
突然 IllegalMonitorStateException がスローされました:
Caused by: java.lang.IllegalMonitorStateException
at java.util.concurrent.locks.ReentrantReadWriteLock$Sync.tryReleaseShared(ReentrantReadWriteLock.java:363)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.releaseShared(AbstractQueuedSynchronizer.java:1317)
at java.util.concurrent.locks.ReentrantReadWriteLock$ReadLock.unlock(ReentrantReadWriteLock.java:745)
ここで、このシナリオと同様の説明を読みました。
なぜこれが起こるのか誰にも分かりますか?