您的位置:首页 > 运维架构 > Linux

linux-使用互斥锁完成多进程同步

2011-10-12 13:08 246 查看
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/mman.h>
#include <unistd.h>

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>

int main(void){//2个进程,一个进程完成每次加1,另一个进程完成每次加2,2个进程协作完成累加,使用共享内存方式在进程间通信

int *x;
int rt;
int shm_id;
char *addnum="myadd";
char *ptr;

pthread_mutex_t mutex;//互斥对象
pthread_mutexattr_t mutexattr;//互斥对象属性

pthread_mutexattr_init(&mutexattr);//初始化互斥对象属性
pthread_mutexattr_setpshared(&mutexattr,PTHREAD_PROCESS_SHARED);//设置互斥对象为PTHREAD_PROCESS_SHARED共享,即可以在多个进程的线程访问,PTHREAD_PROCESS_PRIVATE为同一进程的线程共享
rt=fork();//复制父进程,并创建子进程
//deepfuture.iteye.com,深未来技术原创
if (rt==0){//子进程完成x+1
shm_id=shm_open(addnum,O_RDWR,0);
ptr=mmap(NULL,sizeof(int),PROT_READ|PROT_WRITE,MAP_SHARED,shm_id,0);/*连接共享内存区*/
x=(int *)ptr;

for (int i=0;i<10;i++){//加10次。相当于加10
pthread_mutex_lock(&mutex);
(*x)++;
printf("x++:%d\n",*x);
pthread_mutex_unlock(&mutex);
sleep(1);
}
}
else{//父进程完成x+2
shm_id=shm_open(addnum,O_RDWR|O_CREAT,0644);
ftruncate(shm_id,sizeof(int));
ptr=mmap(NULL,sizeof(int),PROT_READ|PROT_WRITE,MAP_SHARED,shm_id,0);/*连接共享内存区*/
x=(int *)ptr;

for (int i=0;i<10;i++){//加10次,相当于加20
pthread_mutex_lock(&mutex);
(*x)+=2;
printf("x+=2:%d\n",*x);
pthread_mutex_unlock(&mutex);
sleep(1);
}

}
shm_unlink(addnum);//删除共享名称
munmap(ptr,sizeof(int));//删除共享内存
return(0);
}

转自:/article/3763316.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: