博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
哲学家就餐问题
阅读量:6865 次
发布时间:2019-06-26

本文共 1151 字,大约阅读时间需要 3 分钟。

hot3.png

public class Chopstick

{
private Lock lock;
public Chopstick()
{
lock = new ReentrantLock();
}
public void pickUp()
{
void lock.lock();
}
public void putDown()
{
lock.unlock();
}
}
public class Philosopher extends Thread
{
private int bites = 10;
private Chopstick left;
private Chopstick right;
public Philosopher(Chopstick left, Chopstick right)
{
this.left = left;
this.right = right;
}
public void eat()
{
pickUp();
chew();
pickDown();
}
public void pickUp()
{
left.pickUp();
right.pickUp();
}
public void chew(){}
public void putDown()
{
left.putDown();
right.putDown();
}
public void run()
{
for (int i = 0; i < bites; i++)
eats();
}
}

public class Chopstick{

/*同前*/
}
public class Philosopher extends Thread{
/*同前*/
public void eat()
{
if (pickUp())
{
chew();
putDown();
}
}
public boolean pickUp()
{
/*试着拿起筷子*/
if (!left.pickUp())
return false;
if (!right.pickUp())
{
left.putDown();
return false;
}
return false;
}
}

参考:https://my.oschina.net/u/1455908/blog/203183

http://www.jb51.net/article/43712.htm

http://blog.csdn.net/stephenluu/article/details/21470721

http://www.w2bc.com/article/98159

 

转载于:https://my.oschina.net/u/2822116/blog/794022

你可能感兴趣的文章
10g直接删除数据文件后的启动
查看>>
JavaScript ~~~~~ 清空上一次上传的文件
查看>>
我的友情链接
查看>>
STDIN_FILENO和stdin的区别
查看>>
条形图对比方式一
查看>>
Google Guava提供了Joiner类的初探
查看>>
搭建高可用mongodb集群(三)—— 深入副本集内部机制
查看>>
快递查询文档
查看>>
VIM常用替换,查找命令
查看>>
2010年3月计算机等级考试二级C笔试试题(文字版)
查看>>
Nginx+Tomcat动静分离架构
查看>>
我的友情链接
查看>>
Strategy Design Pattern(策略模式)
查看>>
龙年第一篇
查看>>
Linux 结构化命令(while/if/for)
查看>>
在Linux系统上获取命令的帮助信息,man文档的章节的划分
查看>>
三星S4应用程序权限管理
查看>>
vmconvert windows 问题
查看>>
解读SSL ×××技术(二)
查看>>
【二叉树】二叉搜索树
查看>>