pthread_mutex互斥锁多进程共享

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/mman.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>


typedef struct _FOO
{
int nCount;
int nData;
}FOO,*PFOO;


int main(int argc,char *argv[])
{
FOO *ptr;
pid_t pid;


pthread_mutexattr_t mutexattr;
pthread_mutex_t mutex;


pthread_mutexattr_init(&mutexattr);
pthread_mutexattr_setpshared(&mutexattr,PTHREAD_PROCESS_SHARED); //设置为进程共享

pthread_mutex_init(&mutex,&mutexattr);

ptr = (PFOO)mmap(NULL,sizeof(FOO),PROT_READ | PROT_WRITE,MAP_SHARED|MAP_ANON,-1,0); //匿名内存映射,让父子进程都操作ptr指向的内存区,如果不使用共享内存,则父子进程的ptr指向的是各自的内存空间
ptr->nCount = 1;
ptr->nData = 2;
printf("%d,%d\n",ptr->nCount,ptr->nData);
if( (pid = fork()) < 0)
{
printf("fork error\n");
return -1;

else if( 0 == pid) //子进程
{
for(int i = 0;i<3;i++)
{
pthread_mutex_lock(&mutex);
ptr->nCount++;
printf("child ++ === %d\n",ptr->nCount);
pthread_mutex_unlock(&mutex);
usleep(1000);
}
}
else //父进程
{
for(int i = 0;i<3;i++)
{
pthread_mutex_lock(&mutex);
ptr->nCount += 2;
printf("parent +2 === %d\n",ptr->nCount);
pthread_mutex_unlock(&mutex);
usleep(1000);
}
}
waitpid(pid,NULL,0);
munmap(NULL,sizeof(FOO));
return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 答:pthread_mutex_init有三种互斥锁:PTHREAD_MUTEX_NORMAL、PTHREAD_MUTEX_ERRORCHECK和PTHREAD_MUTEX_RECURSIVE。PTHREAD_MUTEX_NORMAL是最基本的互斥锁,它只支持加锁和解锁操作;PTHREAD_MUTEX_ERRORCHECK可以检测死锁和重复加锁;PTHREAD_MUTEX_RECURSIVE可以支持多次加锁,解锁也需要多次才能完全解开锁。 ### 回答2: pthread_mutex_init函数是用于初始化互斥锁的函数,它可以创建三种不同类型的互斥锁,分别是普通锁(PTHREAD_MUTEX_NORMAL)、错误检查锁(PTHREAD_MUTEX_ERRORCHECK)和递归锁(PTHREAD_MUTEX_RECURSIVE),它们之间的区别如下: 1. 普通锁(PTHREAD_MUTEX_NORMAL): 普通锁是最基本的互斥锁类型,它没有提供死锁检测功能。如果同一个线程对已经加锁的互斥锁再次调用pthread_mutex_lock函数,就会出现死锁情况,进程可能会陷入无法继续执行的状态。因此,在使用普通锁时需要特别注意避免死锁。 2. 错误检查锁(PTHREAD_MUTEX_ERRORCHECK): 错误检查锁是一种提供了死锁检测功能的互斥锁类型。当同一个线程对已经加锁的错误检查锁再次调用pthread_mutex_lock函数时,线程不会进入死锁状态,而是会返回一个错误码,通过这个错误码可以判断是否出现死锁。这种互斥锁类型增加了线程之间的安全性,但会带来些许额外的开销。 3. 递归锁(PTHREAD_MUTEX_RECURSIVE): 递归锁是允许同一个线程多次对互斥锁进行加锁操作的锁类型。在同一个线程内部,可以对已经加锁的互斥锁再次加锁,而不会造成死锁。需要注意的是,每次对递归锁进行加锁操作时,都必须相应的进行解锁操作,否则其他线程无法对该锁进行加锁。递归锁常用于复杂的程序设计中,可以简化处理复杂情况时的加锁解锁操作。 以上是三种不同类型的互斥锁的区别。根据实际需求,选择合适的互斥锁类型可以有效地保证线程的安全性和程序的正常运行。 ### 回答3: pthread_mutex_init函数是用来初始化互斥锁的,它提供了三种不同类型的互斥锁,分别是普通锁(PTHREAD_MUTEX_NORMAL)、递归锁(PTHREAD_MUTEX_RECURSIVE)和错误检查锁(PTHREAD_MUTEX_ERRORCHECK)。这三种锁在使用上有一些区别。 1. 普通锁(PTHREAD_MUTEX_NORMAL): 普通锁是最简单的一种互斥锁类型。当一个线程占用了该锁后,其他线程将被阻塞。如果同一个线程再次请求这个锁,就会产生死锁。因此,对于普通锁,需要确保锁的获取和释放是成对的且不会有嵌套的请求。 2. 递归锁(PTHREAD_MUTEX_RECURSIVE): 递归锁可以被同一个线程多次获取,并能够正常释放。这意味着同一个线程在持有锁的同时可以多次请求该锁,而不会产生死锁。递归锁使用一个计数器来跟踪锁的持有次数,每次请求时计数器加1,每次释放时计数器减1。只有当计数器为0时,才能被其他线程获取锁。 3. 错误检查锁(PTHREAD_MUTEX_ERRORCHECK): 错误检查锁会在每次对锁的操作(获取、释放)之前进行错误检查,以确保锁的使用是正确的。如果发生了错误的使用,比如同一个线程重复获取锁,或者释放未持有的锁,将会返回一个错误码。错误检查锁在性能上可能会存在一定的开销,因此在性能要求较高的场景下可能不太适用。 一般来说,递归锁比较适用于同一个线程需要多次获取锁的情况,而普通锁适用于不需要嵌套请求的情况。错误检查锁则是为了更加严格地检查锁的正确使用情况。根据具体的使用需求,可以选择适合的互斥锁类型来保证线程安全。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值