互斥量

两个线程访问同一块共享资源,如果不协调顺序,容易造成数据混乱
加锁
mutex
pthread_mutex_init 初始化
pthread_mutex_destroy 摧毁
pthread_mutex_lock 加锁
pthread_mutex_unlock(pthread_mutex_t *mutex) 解锁

互斥量的使用步骤:初始化、加锁、执行逻辑–共享操作数据、解锁
注意事项:加锁需要最小粒度,不要一直占用临界区

尝试加锁
pthread_mutex_trylock(pthread_mutex_t *mutex)

pthread_print.c

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>

pthread_mutex_t mutex=PHTREAD_MUTEX_INITIALIZER;

int sum=0;

void* thr1(void *arg)
{
    while(1){
        //先上锁
        pthread_mutex_lock(&mutex); //加锁当有线程已经加锁的时候会阻塞
        printf("hello");
        sleep(rand()%3);
        printf("world\n");
        //释放锁
        pthread_mutex_unlock(&mutex);
        sleep(rand()%3);
    }
}     

void* thr2(void *arg)
{
    while(1){
        pthread_mutex_lock(&mutex);
        printf("HELLO");
        sleep(rand()%3);
        printf("WORLD\n");
        pthread_mutex_unlock(&mutex);
        sleep(rand()%3);
    }
} 

int main()
{
    pthread_t tid[2];
    pthread_create(&tid[0],NULL,thr1,NULL);
    pthread_create(&tid[1],NULL,thr2,NULL);

    pthread_join(tid[0],NULL);
    pthread_join(tid[1],NULL);
    return 0;
}

mutex_trylock.c

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

pthread_mutex_t mutex;

void* thr(void *arg)
{
    while(1){
        pthread_mutex_lock(&mutex);
        printf("helloworld\n");
        sleep(30);
        pthread_mutex_unlock(&mutex);    
    }
    return NULL}     

int main()
{
    pthread_mutex_init(&mutex);
    pthread_t tid;
    pthread_create(&tid,NULL,thr,NULL);
    sleep(1);
    while(1){
        int ret=pthread_mutex_trylock(&mutex);
        if(ret>0){
             printf("ret=%d,srrmsg:%s\n",ret,strerror(ret));
        }
        sleep(1);
    }
    return 0;
}

死锁:
锁了又锁,自己加了一次锁后又加了一次
交叉锁(每个线程申请锁的顺序要一致,如果申请到一把锁,再申请另外一把时申请失败,应该释放已经掌握的)

互斥量只是建议锁

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

给算法爸爸上香

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值