文档章节

哲学家就餐问题

一贱书生
 一贱书生
发布于 2016/11/25 09:38
字数 145
阅读 6
收藏 0

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

 

© 著作权归作者所有

共有 人打赏支持
一贱书生
粉丝 19
博文 724
码字总数 600123
作品 0
java中的死锁问题研究

1.什么是死锁: 百度百科的定义: 所谓死锁:是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统...

双月通天
2016/06/06
54
0
哲学家就餐问题——MFC演示程序

这个问题实际上就是多线程的调度问题,因为MFC里面已经给我们封装好了线程类,CWinThread类,因此我们要做的仅仅是简单的为每位哲学家分别创建进程。程序逻辑不是很复杂,但在用MFC来做哲学家...

晨曦之光
2012/05/23
138
0
Android第二十天

一:同步机制(synchronized) 同步:在一个时间段内只能有一个线程运行某段代码块,在该线程运行的过程中, 其他线程不能进入,只有该线程运行完毕该代码块(或释放了同步锁),其他 线程才能...

黄晓磊
2016/06/24
11
0
Lock应用之 尝试锁获取

当线程请求内部锁时,如果锁已经被占用,则请求线程必须无条件等待,这往往会造成很多奇怪问题,相互等待是造成死锁的重要原因之一,著名的哲学家就餐问题就是个典型的案例。新的Lock锁提供了...

技术小胖子
2017/11/16
0
0
OS学习笔记八:死锁

一、死锁的基本概念 1、死锁的定义 一组进程中,每个进程都无限等待被该组进程中另一进程所占有的资源,因而永远无法得到的资源,这种现象称为 进程死锁 ,这一组进程就称为死锁进程 如果死锁...

xunzaosiyecao
2017/10/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

centos7安装Nginx

安装所需环境 一. gcc 安装 安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装: yum install gcc-c++ 二. PCRE pcre-devel 安装 PCRE(Perl Co...

狼王黄师傅
9分钟前
0
0
dubbo+apollo微服务开发指南

为了大家比较快速的开发微服务,规范dubbo,spring,mybatis,hessian,netty的版本和用法,我写了一个demo,下面对demo的功能做个简单的介绍,如有疑问的地方,可以私下问我。 微服务项目示例 ...

PageYi
11分钟前
0
0
android流式布局、待办事项应用、贝塞尔曲线、MVP+Rxjava+Retrofit、艺术图片应用等源码

Android精选源码 android模仿淘宝首页效果源码 一款艺术图片应用,采用T-MVVM打造 Android MVP + RxJava + Retrofit项目 android流式布局实现热门标签效果 android仿淘宝客户端商品详情页效果...

Android爱开源
13分钟前
0
0
一步一步安装hive

The Apache Hive ™ data warehouse software facilitates reading, writing, and managing large datasets residing in distributed storage using SQL. Structure can be projected onto d......

hnairdb
16分钟前
0
0
【WebService 系列二 使用JAX-WS开发示例程序】

1、服务端代码 1.1、编写SEI SEI即(Service Endpoint Interface)SEI在ws中称为portType,在java中称为接口 package jaxws.server;/** * @className: HelloService * @description: jax......

HansonReal
26分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部