linux c 进程间互斥,linux-多线程-互斥锁在多进程共享

#include

#include

#include

#include

#include

#include

#include

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.javaeye.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);

}

?编译

deepfuture@deepfuture-laptop:~/private/mytest$ gcc ?-lpthread -std=c99 -lrt -o testmutex testmutex.c

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值