5

私のアプリケーションは、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) 

ここで、このシナリオと同様の説明を読みました。

なぜこれが起こるのか誰にも分かりますか?

4

0 に答える 0