Linux环境互斥锁

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

pthread_mutex_t mutex;
int sum = 0;

typedef struct FuncArg
{
    int start;
    int end;
}FuncArg;

void *thread_handler(void *arg)
{
    int start = ((FuncArg*)arg)->start + 1;
    int end = ((FuncArg*)arg)->end;
    
    for(;start <= end; ++start)
    {
        pthread_mutex_lock(&mutex);   //申请锁
        sum += start;                 //临界区操作
        pthread_mutex_unlock(&mutex); //释放锁
    }
    return 0;
}

int main(int argc,char* argv[])
{
    pthread_t thids[4];
    FuncArg arg[4];
    
    pthread_mutex_init(&mutex,NULL); //初始化互斥锁
    
    int len = 10000/4;
    for(int i = 0;i < 4;++i)
    {
        arg[i].start = len*i;
        arg[i].end = len*( i + 1);
        pthread_create(&thids[i],NULL,thread_handler,&arg[i]);
    }
    
    for(int i = 0;i < 4;++i)
    {
        int *ret;
        pthread_join(thids[i],(void**)&ret);
    }
    
    pthread_mutex_destroy(&mutex);
    printf("sum = %d\n",sum);
    
    return EXIT_SUCCESS;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux 中用于实现互斥锁的函数包括 pthread_mutex_init()、pthread_mutex_lock()、pthread_mutex_trylock() 和 pthread_mutex_unlock()。 ### 回答2: 在Linux中,互斥锁的实现函数是通过pthread库提供的函数来完成的。其中,互斥锁的创建、加锁和解锁可以分别使用`pthread_mutex_init`、`pthread_mutex_lock`和`pthread_mutex_unlock`函数。 首先,在使用互斥锁前需要先创建互斥锁。`pthread_mutex_init`函数用于初始化一个互斥锁对象,并且可以设置互斥锁的属性,如互斥锁的类型等。 然后,使用`pthread_mutex_lock`函数对临界资源进行加锁操作。加锁操作会使得其他线程在尝试对同一互斥锁进行加锁操作时被阻塞,直至当前线程释放锁。 最后,使用`pthread_mutex_unlock`函数对互斥锁进行解锁操作。解锁操作会释放对互斥锁的占用,使得其他线程可以对该互斥锁进行加锁操作。 同时,还可以使用`pthread_mutex_trylock`函数来尝试对互斥锁进行加锁操作,但是不会阻塞当前线程。如果锁已经被其他线程占用,则该函数会返回错误码,可以根据该返回值进行相关处理。 互斥锁的实现函数可以保证在多线程环境中对共享资源的安全访问。通过加锁和解锁操作,可以确保每一时刻只有一个线程访问临界资源,从而避免了竞态条件和数据不一致的问题。 ### 回答3: Linux互斥锁的实现函数包括pthread_mutex_init、pthread_mutex_lock、pthread_mutex_trylock、pthread_mutex_unlock和pthread_mutex_destroy。 1. pthread_mutex_init函数用于初始化互斥锁,其原型为: ``` int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *attr); ``` 该函数将互斥锁mutex初始化为默认属性attr。 2. pthread_mutex_lock函数用于加锁互斥锁,其原型为: ``` int pthread_mutex_lock(pthread_mutex_t *mutex); ``` 调用该函数后,如果互斥锁已被其他线程占用,则调用线程会被阻塞,直到互斥锁可用。 3. pthread_mutex_trylock函数用于尝试加锁互斥锁,其原型为: ``` int pthread_mutex_trylock(pthread_mutex_t *mutex); ``` 调用该函数后,如果互斥锁已被其他线程占用,则函数会立即返回一个错误码,而不是阻塞。 4. pthread_mutex_unlock函数用于解锁互斥锁,其原型为: ``` int pthread_mutex_unlock(pthread_mutex_t *mutex); ``` 调用该函数后,互斥锁变为可用状态,其他线程可以尝试加锁。 5. pthread_mutex_destroy函数用于销毁互斥锁,其原型为: ``` int pthread_mutex_destroy(pthread_mutex_t *mutex); ``` 该函数释放与互斥锁相关的资源。 总结起来,Linux中的互斥锁实现函数可以帮助我们创建、加锁、解锁和销毁互斥锁,以保证多线程之间对共享资源的安全访问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值