1. 程式人生 > >Linux下的多程序間共享資源的互斥訪問

Linux下的多程序間共享資源的互斥訪問

分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow

也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!

               
#include    <stdio.h>  #include    <stdlib.h>  
#include    <unistd.h>  #include    <fcntl.h>  #include    <sys/mman.h>  #include    <pthread.h>  pthread_mutex_t* g_mutex;  //建立共享的mutex  void init_mutex(void)  {      int
ret;      //g_mutex一定要是程序間可以共享的,否則無法達到程序間互斥      g_mutex=(pthread_mutex_t*)mmap(NULL, sizeof(pthread_mutex_t), PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0);      if( MAP_FAILED==g_mutex )      {          perror("mmap"
);          exit(1);      }            //設定attr的屬性      pthread_mutexattr_t attr;      pthread_mutexattr_init(&attr);      //一定要設定為PTHREAD_PROCESS_SHARED      //具體可以參考http://blog.chinaunix.net/u/22935/showart_340408.html      ret=pthread_mutexattr_setpshared(&attr,PTHREAD_PROCESS_SHARED);      if( ret!=0 )      {          perror("init_mutex pthread_mutexattr_setpshared");          exit(1);      }      pthread_mutex_init(g_mutex, &attr);  }  int main(int argc, char *argv[])  {      init_mutex();      int ret;          char str1[]="this is child process/r/n";      char str2[]="this is father process/r/n";      int fd=open("tmp", O_RDWR|O_CREAT|O_TRUNC, 0666);      if( -1==fd )      {          perror("open");          exit(1);      }      pid_t pid;      pid=fork();      if( pid<0 )      {          perror("fork");          exit(1);      }      else if( 0==pid )      {          ret=pthread_mutex_lock(g_mutex);          if( ret!=0 )          {              perror("child pthread_mutex_lock");          }          sleep(10);//測試是否能夠阻止父程序的寫入          write(fd, str1, sizeof(str1));          ret=pthread_mutex_unlock(g_mutex);            if( ret!=0 )          {              perror("child pthread_mutex_unlock");          }         }      else      {          sleep(2);//保證子程序先執行           ret=pthread_mutex_lock(g_mutex);          if( ret!=0 )          {              perror("father pthread_mutex_lock");          }          write(fd, str2, sizeof(str2));          ret=pthread_mutex_unlock(g_mutex);            if( ret!=0 )          {              perror("father pthread_mutex_unlock");          }                     }      wait(NULL);      munmap(g_mutex, sizeof(pthread_mutex_t));  } 


執行後tmp檔案內容為:

this is child process

this is father process



           

給我老師的人工智慧教程打call!http://blog.csdn.net/jiangjunshow

這裡寫圖片描述