共有変数を使用する複数のスレッドがありますqueue
。それを処理(印刷)した後、要素をキューから削除します
protected void tryToPrint() {
while (true) {
try {
if (printer.isAvailable() && printer.isFair(this)) {
queueLock.lock();
try {
if (queue.isEmpty())
break;
printer.requestToPrint(this, queue.get(0));
queue.remove(0);
synchronized (System.out) {
System.out.println(getName() + " printed. queue size: " + queue.size());
}
} finally {
queueLock.unlock();
}
} else {
printer.requestToPrintNext(this);
}
} catch (IllegalPrintStateException e) {
e.printStackTrace();
}
}
}
しかし、私は得ています
Exception in thread "Thread-1" java.lang.IndexOutOfBoundsException: Index: 0, Size: 0
at java.util.ArrayList.rangeCheck(ArrayList.java:604)
at java.util.ArrayList.remove(ArrayList.java:445)
at printer.ClientImpl.tryToPrint(ClientImpl.java:34)
at printer.AbstractClient.run(AbstractClient.java:28)
at java.lang.Thread.run(Thread.java:722)
別のスレッドがどういうわけかキューから要素を削除したと思いますか? ロックしたのにどうしてそんなことができるの?
UPDATE : queue は実際にはArrayList<File>()
. スレッドセーフでなくても問題ありませんか? 私はロックしましたqueueLock
か?