Chinaunix首页 | 论坛 | 博客
  • 博客访问: 110936
  • 博文数量: 94
  • 博客积分: 2245
  • 博客等级: 大尉
  • 技术积分: 613
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-26 16:35
文章分类

全部博文(94)

文章存档

2013年(8)

2012年(86)

我的朋友

分类: C/C++

2012-09-08 15:14:19

  pthread的mutex通常用在多线程的同步当中,至于多进程的同步,一直以为只能使用记录锁和信号量,而这两种机制都需要内核的支 持,属于“重量级”部件。也曾经在多进程同步中使用pthread mutex,但前提有两个:mutex能为多个进程所见,使mutex对象驻留在共享内存中;mutex本身不额外使用进程本地的内存,如堆内存。第一个 前提容易满足,对于第二个,GCC的pthread实现也满足。但我一直没有注意到的是,pthread mutex标准本身对多进程提供了“可选”支持,只要实现支持、初始化mutex时pthread_mutexattr_t的pshared成员置为 PTHREAD_PROCESS_SHARED即可。
  pshared默认为PTHREAD_PROCESS_PRIVATE,即仅支持单进程。如果mutex驻留于共享内存,但pshared为 PTHREAD_PROCESS_PRIVATE,此时多进程操作该mutex的行为是未定义的。这两天在写一个多进程可访问的库时就出现了这种“未定 义”的行为,花费了一个多工作日才找到原因。
  多进程使用mutex需要的基本操作如下:


点击(此处)折叠或打开

  1. #include <pthread.h>
  2. #include <sys/mman.h>
  3. #include <sys/types.h>
  4. pthread_mutex_t *mtx = NULL;
  5. int main() {
  6.   //~ reside mutex in shm
  7.   mtx = (pthread_mutex_t*)mmap(NULL, sizeof(pthread_mutex_t), PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANON, -1, 0);
  8.   if (mtx == MAP_FAILED) {
  9.     perror("mmap");
  10.     exit(1);
  11.   }
  12.   pthread_mutexattr_t attr;
  13.   pthread_mutexattr_init(&attr); //~necessary, or weird EINVAL error occurs when operating on the mutex
  14.   pthread_mutexattr_setpshared(&attr, PTHREAD_PROCESS_SHARED);
  15.   pthread_mutex_init(mtx, &attr);
  16.   //~ here the fork
  17.   pid_t pid = fork();
  18.   if (pid < 0) {
  19.     perror("fork");
  20.     exit(1);
  21.   } else if (pid > 0) {
  22.     //~ parent
  23.     //~ lock lock lock
  24.   } else {
  25.     //~ child
  26.     //~ lock lock lock
  27.   }
  28.   return 0;
  29. }

阅读(3867) | 评论(1) | 转发(1) |
给主人留下些什么吧!~~

wxfjx2013-12-24 17:07:25

父子进程的可以实现同步,能给个两个独立进程之间如何同步的例子吗?