日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > linux >内容正文

linux

哲学家就餐问题linux源代码,Linux下实现哲学家就餐问题

發(fā)布時(shí)間:2025/3/20 linux 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 哲学家就餐问题linux源代码,Linux下实现哲学家就餐问题 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

#include //筷子作為mutex

pthread_mutex_t chopstick[6] ;//定義以筷子為鎖的數(shù)組

void *eat_think(void *arg)

{

char phi = *(char *)arg; //將任意類型的指針*arg轉(zhuǎn)化為*char類型

int left,right; //左右筷子的編號(hào)

switch (phi){

case 'A':

left = 5;

right = 1;

break;

case 'B':

left = 1;

right = 2;

break;

case 'C':

left = 2;

right = 3;

break;

case 'D':

left = 3;

right = 4;

break;

case 'E':

left = 4;

right = 5;

break;

}

int i;

for(;;){

usleep(3); //思考,將進(jìn)程掛起一段時(shí)間

pthread_mutex_lock(&chopstick[left]); //拿起左手的筷子,鎖定互斥量,加鎖

printf("Philosopher %c fetches chopstick %d\n", phi, left);輸出哲學(xué)家拿起了左手邊的筷子

if (pthread_mutex_trylock(&chopstick[right]) == EBUSY){ //判斷右手的筷子是否有人用, 再試一次獲得對(duì)互斥量的鎖定(非阻塞)

pthread_mutex_unlock(&chopstick[left]); //如果右邊筷子被拿走放下左手的筷子,解鎖互斥量,解鎖

continue;//如果此哲學(xué)家沒能吃飯,驗(yàn)證下一個(gè)哲學(xué)家是否能吃飯,即跳出本次循環(huán)進(jìn)行下次循環(huán)

}

// pthread_mutex_lock(&chopstick[right]); //拿起右手的筷子,如果想觀察死鎖,把上一句if注釋掉,再把這一句的注釋去掉

printf("Philosopher %c fetches chopstick %d\n", phi, right); //輸出此哲學(xué)家又拿起了右手邊的跨子

printf("Philosopher %c is eating.\n",phi);//輸出此次的哲學(xué)家拿起啦一雙筷子在吃飯

usleep(3); //吃飯,把進(jìn)程掛起一段時(shí)間

pthread_mutex_unlock(&chopstick[left]); //放下左手的筷子

printf("Philosopher %c release chopstick %d\n", phi, left);

pthread_mutex_unlock(&chopstick[right]); //放下右手的筷子

printf("Philosopher %c release chopstick %d\n", phi, right);

}

}

int main(){

pthread_t A,B,C,D,E; //5個(gè)哲學(xué)家

int i;

for (i = 0; i < 5; i++)

pthread_mutex_init(&chopstick[i],NULL);//初始化默認(rèn)互斥鎖屬性的互斥鎖數(shù)組chopstick[i],默認(rèn)屬性為快速互斥鎖

pthread_create(&A,NULL, eat_think, "A");創(chuàng)建并跳轉(zhuǎn)到線程函數(shù)創(chuàng)建并跳轉(zhuǎn)到參數(shù)為指向線程標(biāo)識(shí)符的指針為 A 線程函數(shù)eat_think,A是運(yùn)行函數(shù)的參數(shù)

pthread_create(&B,NULL, eat_think, "B");

pthread_create(&C,NULL, eat_think, "C");

pthread_create(&D,NULL, eat_think, "D");

pthread_create(&E,NULL, eat_think, "E");

pthread_join(A,NULL);//等待線程標(biāo)識(shí)符為 A 的eat_think線程函數(shù)結(jié)束

pthread_join(B,NULL);

pthread_join(C,NULL);

pthread_join(D,NULL);

pthread_join(E,NULL);

return 0;

}

總結(jié)

以上是生活随笔為你收集整理的哲学家就餐问题linux源代码,Linux下实现哲学家就餐问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。