【发布时间】:2017-06-05 16:22:29
【问题描述】:
public class semaphoreTest {
static LinkedList<Integer> integerLinkedList = new LinkedList<>();
static Semaphore semaphore = new Semaphore(1);
static Object lock = new Object();
public static void main(String[] args) throws InterruptedException {
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
try {
produce();
} catch (InterruptedException e) {
}
}
});
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
try {
consume();
} catch (InterruptedException e) {
}
}
});
t1.start();
t2.start();
t1.join();
t2.join();
}
private static void produce() throws InterruptedException {
semaphore.acquire();
int value = 0;
while (true) {
while (integerLinkedList.size() == 10) {
semaphore.release();
}
integerLinkedList.add(value++);
}
}
private static void consume() throws InterruptedException {
semaphore.acquire();
while (true) {
while (integerLinkedList.size() == 0) {
semaphore.release();
}
//semaphore.release();
Integer value = integerLinkedList.removeFirst();
System.out.println("Size of the List is " + integerLinkedList.size() + " and value removed is " + value);
semaphore.release();
Thread.sleep(100);
}
}
}
这是我尝试使用信号量作为锁编写的生产者消费者问题。但我几乎不知道删除了大约 240 个元素后,它给出了一条错误消息,为 Maximum permit count exceeded。
我在正确的位置释放锁,但无法弄清楚获取部分的错误。
错误信息如下:
Exception in thread "Thread-0" java.lang.Error: Maximum permit count exceeded
at java.util.concurrent.Semaphore$Sync.tryReleaseShared(Semaphore.java:192)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.releaseShared(AbstractQueuedSynchronizer.java:1341)
at java.util.concurrent.Semaphore.release(Semaphore.java:426)
at interviewQuestions.semaphoreTest.procude(semaphoreTest.java:53)
at interviewQuestions.semaphoreTest.access$000(semaphoreTest.java:12)
at interviewQuestions.semaphoreTest$1.run(semaphoreTest.java:23)
at java.lang.Thread.run(Thread.java:745)
Exception in thread "Thread-1" java.lang.Error: Maximum permit count exceeded
at java.util.concurrent.Semaphore$Sync.tryReleaseShared(Semaphore.java:192)
at java.util.concurrent.locks.AbstractQueuedSynchronizer.releaseShared(AbstractQueuedSynchronizer.java:1341)
at java.util.concurrent.Semaphore.release(Semaphore.java:426)
at interviewQuestions.semaphoreTest.consume(semaphoreTest.java:72)
at interviewQuestions.semaphoreTest.access$100(semaphoreTest.java:12)
at interviewQuestions.semaphoreTest$2.run(semaphoreTest.java:33)
at java.lang.Thread.run(Thread.java:745)
【问题讨论】:
标签: java multithreading semaphore