Linux互斥锁

时间:2021-07-20
本文章向大家介绍Linux互斥锁,主要包括Linux互斥锁使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

互斥锁的作用:// 在某一时刻,只允许一个线程访问临界资源
例如:在线程1里面会对全局变量进行修改,在线程2里面也会对与线程1相同的全局变量进行修改,为了相互不影响,我们希望在线程1操作这个变量的时候线程2不能操作这个变量,或者在线程2操作这个变量的时候线程1不能操作这个变量,也就是在同一时间只能有一个线程操作此变量。则我们可以在两个线程对应数据操作的位置加上均互斥锁,则可实现该功能。(其实不限于数据的变化,通俗的来说就是互斥锁上锁和开锁所对应的那一段代码。)

//互斥锁头文件
#include <pthread.h>


//定义出一个互斥锁变量
pthread_mutex_t mutex;
int main()
{
    //在主函数初始化互斥锁
    if(0 != pthread_mutex_init(&mutex, NULL))
    {
        perror("mutex");
        return -1;
    } 
}

//上锁
pthread_mutex_lock(&mutex);

//对数据进行操作   

//释放锁
pthread_mutex_unlock(&mutex);

注意:多线程程序在编译的时候需要链接对应的库-lpthread

原文地址:https://www.cnblogs.com/JinShanCheShen/p/15036332.html