5個哲學家搶叉子程式. 示範死結

來源:互聯網
上載者:User

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
                                          
enum { N = 5 };                           /* number of philosphers */

static HANDLE fork[N];          /* model forks as mutex semaphores */

void think(long n) {
   printf("Philosopher %d is thinking\n", n);
   Sleep(10);
   printf("Philosopher %d is hungry\n", n);

void eat(long n) {
   printf("Philosopher %d is eating\n", n);
   Sleep(0);

long WINAPI philosopher(long n) {   /* model philosophers as tasks */
   for (;;) { 
      think(n);               // first the philosopher thinks for a while
                      // after thinking the philosopher becomes hungry...
      WaitForSingleObject(fork[(n + 1) % N], INFINITE);  // get left fork
      Sleep(0);             /* yield讓出 the CPU (simulate preemption ) 去掉這句就不會死結了嗎?*/
      WaitForSingleObject(fork[n], INFINITE);           // get right fork
      eat(n);                      // got both forks, can eat for a while
      ReleaseMutex(fork[(n + 1) % N]);               // release left fork
      ReleaseMutex(fork[n]);                        // release right fork
   }
   return 0;

main() {
   int n;
   for (n = 0; n < N; ++n) {                       /* create forks */
  fork[n] = CreateMutex(NULL,
// default security attributes
  FALSE,
// initially not owned/* not owned */
  NULL);
// unnamed mutex

  if (fork[n] == NULL) 
  {
  printf("CreateMutex error: %d\n", GetLastError());
  return;
  }
 
   }
   for (n = 0; n < N; ++n) {                /* create philosophers */
      int threadID;
 CloseHandle(CreateThread(
 NULL,        // default security attributes
 0,           // default stack size
 (LPTHREAD_START_ROUTINE)philosopher,
 (LPVOID)n,    //  thread function arguments
 0,            // default creation flags
 &threadID));  //thread identifier
   }
   scanf("%c", &n);            /* wait for the user to press Enter */    
   return 0;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.