我一直在从事哲学家就餐任务,但我遇到了一个问题,我的代码围绕 3 个类,叉子、哲学家和 dinerTable(是的,我错误地用小写字母命名了最后两个)。
代码正常启动,哲学家 0 和 2 抓住他们的叉子,但随后代码停止了,谁能帮帮我吗?
有3类:
叉子(扩展线程):
public synchronized boolean isFree() throws InterruptedException
{
return available;
}
public synchronized void returnFork() throws InterruptedException
{
available = true;
this.notify();
}
public synchronized void takeFork() throws InterruptedException
{
available = false;
this.notify();
}
哲学家(实现可运行):
private int number;
private Forks right;
private Forks left;
private boolean hasBothForks;
private boolean keepGoing;
public boolean isKeepGoing() {
return keepGoing;
}
public void setKeepGoing(boolean keepGoing) {
this.keepGoing = keepGoing;
}
public philosophers(int number,Forks right, Forks left, boolean keepGoing)
{
this.number = number;
this.right = right;
this.left = left;
hasBothForks = false;
this.keepGoing = keepGoing;
}
private void print(String message)
{
System.out.println("Philosopher " + number + " " + message );
}
@Override
public void run() {
if(keepGoing == true)
{
try
{
print("is hungry");
print( "checks if forks are free");
if(right.isFree() == true && left.isFree() == true && hasBothForks == false)
{
print("is grabbing forks");
right.takeFork();
left.takeFork();
hasBothForks = true;
} // end if
else if(hasBothForks == true)
{
print("is eating");
Thread.sleep(2000);
print("is putting down left fork");
left.returnFork();
print("is putting down right fork");
right.returnFork();
print("is finished eating");
hasBothForks = false;
} // end if
else if(right.isFree() == false && left.isFree() == false && hasBothForks == false)
{
print("is thinking");
Thread.sleep(2000);
} // end if
} // end try
catch (InterruptedException e) {
print(" is interrupted");
} // end catch
} // end if
} // end run
餐桌:
private static int num = 5;
private static Forks right = null;
private static Forks left = null;
private static Forks[] forks = new Forks[num];
private static philosophers[] philosophers = new philosophers[num];
public static void main(String args[])
{
for (int i = 0; i < num ; i++)
{
forks[i] = new Forks();
}
for (int i = 0; i < num; i++)
{
if (i > 0)
{
left = forks[i - 1];
right = forks[i];
} // end if
else if ( i == 0)
{
left = forks[num-1];
right = forks[i];
} // end if
philosophers[i] = new philosophers(i, right, left, true);
Thread thread = new Thread(philosophers[i]);
thread.start();
} // end for
System.out.print("\n");
}