操作系统哲学家进餐问题java源码实现
时间: 2023-12-06 08:03:50 浏览: 106
好的,这里是操作系统哲学家进餐问题的Java程序实现:
```java
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class DiningPhilosophers {
private static final int NUMBER_OF_PHILOSOPHERS = 5;
private static final int SIMULATION_TIME = 1000;
public static void main(String[] args) throws InterruptedException {
Philosopher[] philosophers = new Philosopher[NUMBER_OF_PHILOSOPHERS];
Object[] forks = new Object[NUMBER_OF_PHILOSOPHERS];
Lock[] locks = new Lock[NUMBER_OF_PHILOSOPHERS];
for (int i = 0; i < NUMBER_OF_PHILOSOPHERS; i++) {
forks[i] = new Object();
locks[i] = new ReentrantLock();
}
for (int i = 0; i < NUMBER_OF_PHILOSOPHERS; i++) {
philosophers[i] = new Philosopher(i, forks[i], forks[(i + 1) % NUMBER_OF_PHILOSOPHERS], locks[i],
locks[(i + 1) % NUMBER_OF_PHILOSOPHERS]);
new Thread(philosophers[i]).start();
}
Thread.sleep(SIMULATION_TIME);
for (Philosopher philosopher : philosophers) {
philosopher.setFull(true);
}
}
}
class Philosopher implements Runnable {
private final int id;
private final Object leftFork;
private final Object rightFork;
private final Lock leftLock;
private final Lock rightLock;
private volatile boolean isFull = false;
public Philosopher(int id, Object leftFork, Object rightFork, Lock leftLock, Lock rightLock) {
this.id = id;
this.leftFork = leftFork;
this.rightFork = rightFork;
this.leftLock = leftLock;
this.rightLock = rightLock;
}
@Override
public void run() {
try {
while (!isFull) {
think();
pickUpForks();
eat();
putDownForks();
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
return;
}
}
private void think() throws InterruptedException {
System.out.println("Philosopher " + id + " is thinking");
Thread.sleep((long) (Math.random() * 10000));
}
private void pickUpForks() throws InterruptedException {
leftLock.lock();
try {
System.out.println("Philosopher " + id + " picked up left fork");
rightLock.lock();
try {
System.out.println("Philosopher " + id + " picked up right fork");
} catch (Exception e) {
leftLock.unlock();
throw e;
}
} catch (Exception e) {
rightLock.unlock();
throw e;
}
}
private void eat() throws InterruptedException {
System.out.println("Philosopher " + id + " is eating");
Thread.sleep((long) (Math.random() * 10000));
}
private void putDownForks() {
leftLock.unlock();
rightLock.unlock();
System.out.println("Philosopher " + id + " put down forks");
}
public void setFull(boolean isFull) {
this.isFull = isFull;
}
}
```
这个程序中,有5个哲学家和5个餐叉,每个哲学家需要同时拿到左右两边的餐叉才能进餐,否则需要等待。使用 `Lock` 和 `ReentrantLock` 来实现锁定餐叉。程序的运行时间为1000毫秒,每个哲学家会先思考一段时间,然后尝试拿起餐叉,进餐,然后放下餐叉,最后再开始思考。
阅读全文