我正在调试我们以前的一位开发人员编写的 Android 服务,他的使用Boolean
方式如下:
public static class DownloadQueue extends LinkedHashMap
{
// ...
private Boolean lock = new Boolean(false);
// ...
//typical notify use
synchronized public Object addToHead(Object key, Object value)
{
// ...
synchronized (lock)
{
//IllegalMonitorStateException FROM HERE
lock.notify();
}
// ...
return null;
}
//queue machinery
public DownloadRecord getFirst()
{
// we block because queue is empty
if(this.size() == 0 || (MyApp.isInternetConnectionAvailable() == false))
{
try
{
lock = true;
synchronized (lock)
{
lock.wait(30000);
}
lock = false;
}
catch (InterruptedException e)
{}
//continue operating the queue
// ...
return value;
}
}
我发现的文档IllegalMonitorStateException
表明这是由于没有notify()
从synchronized
块调用引起的;但是,这里显然不是这种情况。我确实想知道范围是否lock
可能是一个问题,或者不同步的分配是否可能是一个问题。所有的引用lock
都是上面的形式,只有一个wait(long)
在队列函数中。
最后一个可能有用的细节:发生这种情况是因为,尽管我们的设备有网络,但我们的 CMS 已关闭。我们借此机会在这种情况下测试应用程序。我怀疑队列可能正在以极快的速度运行,因为失败的下载正在重新排队,所以如果争用条件可能是导致此故障的原因,那么它可能就是这里的原因。
谢谢!