- 1、本文档共5页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
哲学家就餐算法的一种(最节约资源的)java实现方法。
//测试类
public class Test {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Seats seats= new Seats();//创建建一张桌子
ThePh ph1 = new ThePh(seats, 1);//创建几个哲学家,编号
ThePh ph2 = new ThePh(seats, 2);
ThePh ph3 = new ThePh(seats, 3);
ThePh ph4 = new ThePh(seats, 4);
ThePh ph5 = new ThePh(seats, 5);
ThePh ph6 = new ThePh(seats, 6);
ThePh ph7 = new ThePh(seats, 7);
new Thread(ph1).start();//开启他们的线程
new Thread(ph2).start();
new Thread(ph3).start();
new Thread(ph4).start();
new Thread(ph5).start();
new Thread(ph6).start();
new Thread(ph7).start();
}
}
//测试类
//哲学家类
public class ThePh implements Runnable
{ int left; //左手边的筷子号
int right; //右手边的筷子号
int TheNO; //哲学家的号数,算是一个属性
int SNO; //座位号,1-5 五个座位。
boolean ifHoldS; //判断是否占到位置
boolean ifNotAted; //判断是否还没有用餐,初始值为true表示还没用餐。
Seats seats= new Seats(); //新建一张桌子。。。
public ThePh(Seats seats,int TheNO) {
super();
this.ifHoldS=false;
this.seats = seats;
this.TheNO=TheNO;
ifNotAted=true;
}
public synchronized boolean holdingS(){//占座函数。。。
boolean b=false;
if(this.seats.allA()==0){//如果没有人占住位置时,直接随即占一个位置,返回一个true.
int seatN=(int)(Math.random()*5);
this.SNO =seatN+1;
this.seats.setHold(seatN);
b=true;
}else if (this.seats.allA()==1) {//如果有一个人占住了一个位置,则空一个位置去占位,保证两个人占的位置不挨着
for(int i=0;i5;i++){
if(this.seats.getA(i)==1){
if(i+3==5)
this.SNO=5;
else
this.SNO=(i+3)%5;
// System.out.println(No of seat is+this.SNO);
this.seats.setHold(this.SNO-1);
b=true;
break;
}
}
}
return b;
}
public void run() {
// TODO Auto-generated method stub
while(this.ifNotAted){//如果没就餐则进入循环
if(this.ifHoldS){//如果占到位置,则开始就餐
this.right=this.SNO;
if(this.SNO==1) this.left=5;
else
this.left=this.SNO-1;
System.out.println(哲学家 + this.TheNO + 在座位号为 + this.SNO
+ 上开始用餐了。+使用筷子号
您可能关注的文档
- 北京市公共租赁住房申请.doc
- 北京市公务员报考指南.doc
- 北京市留学人才引进.doc
- 北京2011届高考物理要点简析与习题(振动和波).doc
- 北京师大附中高三物理练习⑷.doc
- 北京智恩教育.doc
- 化疗自助手册.doc
- 北京水务.doc
- 北京林业大学硕士研究生入学考试植物生理学 01 02.doc
- 北京电视中心工程质量目标及管理措施(结构).doc
- 大学生职业规划大赛《新闻学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《应用统计学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《音乐学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《中医学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《信息管理与信息系统专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《汽车服务工程专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《水产养殖学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《市场营销专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《音乐表演专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《音乐学专业》生涯发展展示PPT.pptx
文档评论(0)