文档章节

linux下的哲学家问题。。。水水的实验。。。

猜猜我是吧
 猜猜我是吧
发布于 2014/05/30 00:44
字数 408
阅读 39
收藏 0
#include <stdio.h>
#include <pthread.h>
#include <string.h>
#include <sys/time.h>
#include <time.h>
#include <unistd.h>
pthread_t hThread[5];
int cs[5];
int mark;
void philosopher(int n) {
  while(mark) {}
  long long int seed;
  seed = time(NULL);
  while(1) {
  int state = 0;
  seed++;
  srand(seed);
  state = rand()%2;
  if(state == 1) {
    printf("%d号哲学家决定吃饭\n",n+1);
  } else {
    printf("%d号哲学家决定思考\n",n+1);
  }
  int dirct;
  int times;
  seed++;
  srand(seed);
  times = rand()%10;
  int mark1,mark2;
  mark1 = 0;
  mark2 = 0;
  if(state == 1) {
      while(1) {
        if(cs[n] == 0) {
          cs[n] = 1;
          mark1 = 1;
          printf("%d号哲学家拿起了左边的%d号筷子\n",n+1,n+1);
          break;
        }
        if(times == 0) {
          break;
        }
        usleep(1);
        times = times - 1;
        if(times == 0) {
          break;
        }
      }
      while(1) {
        if(cs[(n+1)%5] == 0) {
          cs[(n+1)%5] = 1;
          mark2 = 1;
          printf("%d号哲学家拿起了右边的%d号筷子\n",n+1,(n+1)%5+1);
          break;
        }
        if(times == 0) {
          break;
        }
        usleep(1);
        times = times - 1;
        if(times == 0) {
          break;
        }
      }
    if(mark1 == 1 && mark2 == 1) {
    printf("%d号哲学家开始吃饭\n",n+1);
    }
  } else {
    printf("%d号哲学家开始思考\n",n+1);
  }
  usleep(times);
  if(state == 1) {
    if(mark1 == 1 && mark2 == 1) {
    printf("%d号哲学家吃饭结束\n",n+1);
    }
    if(mark1 == 1) {
    printf("%d号哲学家放下了左边的%d号筷子\n",n+1,n+1);
    cs[n] = 0;
    mark1 = 0;
    }
    if(mark2 == 1) {
    printf("%d号哲学家放下了右边的%d号筷子\n",n+1,(n+1)%5+1);
    cs[(n+1)%5] = 0;
    mark2 = 0;
    }
  } else {
    printf("%d号哲学家思考结束\n",n+1);
  }
  }
}
int main(int argc,char *argv[]) {
  struct timeval tpstart,tpend;
  mark = 1;
  gettimeofday(&tpstart,NULL);
  int i;
  for(i = 0; i < 5; i++) {
    cs[i] = 0;
  }
  for(i = 0; i < 5; i++) {
    pthread_create(&hThread[i],NULL,(void*)philosopher,i);
  }
  mark = 0;
  sleep(50);
  for(i = 0; i < 5; i++) {
  pthread_cancel(hThread[i]);
  }
  return 0;
}


© 著作权归作者所有

共有 人打赏支持
猜猜我是吧
粉丝 10
博文 15
码字总数 7806
作品 0
广州
私信 提问
【AI哲学】哲学在认知科学中的作用

摘 要 哲学到底对认知科学研究有哪些帮助?通过描述哲学家在认知科学研究中扮演的某些角色,我们可以间接地回答这个问题。这些角色包括拓荒者、建筑监理、禅师、绘图员、档案管理员、拉拉队队...

地球折叠
2017/12/06
0
0
Chakra GNU/Linux 2017.10 发布,代号 Geodel

Chakra GNU/Linux 项目发布更新了,版本是 Chakra 2017.10,这个版本代号是 Goedel,以纪念逻辑学家、数学家和哲学家 Kurt Goedel。 2017.10 ISO 是一个维护版本。与往常一样,它是我们的稳定...

周其
2017/10/11
824
8
DHCP服务器的安装

实验要求和步骤: 一、安装DHCP服务器前的准备工作 1、首先在你的计算机上配置一个静态IP 2、分别在Windows 2003 、ubuntu linux下安装dhcp服务器 二、分别对这两个操作系统下的DHCP进行配置...

乔旧女女
2010/10/23
1K
2
Chakra GNU/Linux 2017.03 发布,更新了 Calamares

Chakra GNU/Linux 项目发布更新了,版本是 Chakra 2017.03,代号 “Goedel”。 新版本具有 Calamares 3.0.1.91 系统安装程序的功能,支持在 Btrfs 和 LUKS 加密分区上安装发行版。 这次发布的...

局长
2017/03/15
1K
8
使用vscode+less写wxss

小程序开发者工具实在是用不下去了,原生css也写不下去了,用开发者工具的这几天感觉回到了解放前 🙂️🙂️🙂️ 所以我用回了vscode,顺带看了一下怎么用less转为wxss 用了一个插件,叫...

Lxylona
04/03
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Ugly Number(leetcode263)

Write a program to check whether a given number is an ugly number. Ugly numbers are positive numbers whose prime factors only include 2, 3, 5. Example 1: Input: 6Output: true......

woshixin
16分钟前
0
0
深度模型从研者 眼里的 似然估计 & Hessain 海森矩阵 & Fisher Information (费雪信息)

深度模型的训练的基本依据是最小化模型拟合数据的误差。旨在不仅知其然(如何构建和训练一个深度模型),还应知其所以然(为什么这样训练,可以做哪些优化)。我们就会发现,有很多研究者,在...

刘小米_思聪
20分钟前
0
0
阿里巴巴智能监控新场景的探索

摘要: 智能监控是智能运维的子领域,详细分析。 作者简介 王肇刚 阿里巴巴全球运行指挥中心高级技术专家 智能监控是智能运维的子领域,我们说的监控,探讨的更多是在监控策略,因为可能从数...

阿里云官方博客
22分钟前
1
0
【双十二】12 月 12 日 12 点 12 分限量抢福利,云计算不剁手!

活动详情 1.首充豪礼 双十二当日,新用户首充 200 元送 200 元代金券!仅限前 88 名!先到先得!拼手速!(新用户指 12 月 12 日前已完成注册但从未充值过的用户)
 2.超值返券 双十二当日,...

七牛云
48分钟前
3
0
Calculate Linux 发布 18 LXQt是基于Gentoo的发行版

导读 Calculate Linux 是一个基于 Gentoo 并与 Gentoo 完全兼容的滚动更新发行版家族,专为企业环境下的快速部署而优化。其提供多个不同的分支版本,分别适用于桌面、服务器等应用场景。该项...

问题终结者
50分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部