本篇我记录一下自己学习互斥锁的成果。
线程同步的概述:
当线程A在对一个共享资源执行写操作时,如果此时线程B恰好也对这个共享资源执行写操作,那么在进程中就会出现两个线程同时对这个共享资源进行写操作,会出现什么结果呢?当然是会破坏我们写入的数据,造成不可预计的错误。
而使用互斥锁(mutex)就正好可以解决这一问题,当线程A在操作(读/写)共享资源时,对其进行加锁,此时如果线程B也要对这个共享资源进行操作时,由于这个锁的存在会线程B被阻塞,直到线程A释放掉它之前加在这个共享资源上的锁时,线程B才会变成可运行状态。
我使用伪代码来表示:
lock(&mutex);
访问共享资源
unlock(&mutex);
其本质并不是把数据“锁住”,而是为线程提供一种串行化执行的机制(让不同的线程避免在同一时间去操作数据),我曾做过一个验证,fun1和fun2是供不同线程执行的程序,如果我注销掉fun2的锁,并且在fun1锁住后不释放,那么在线程调用fun2的时候它依旧会操作到数据。
正常情况下,如果fun1和fun2遵循我们的互斥锁约定,当其中任何一个线程获得互斥锁后,其他试图获得这个锁的线程都会被阻塞,这样就巧妙的将两个线程分别安排在不同的时段执行,保证了任何时刻下只有唯一的线程有“权利”去操作这个共享资源。(我一开始也是误解了互斥锁的真正含义,后来经过多次实例验证才知道这点)
代码如下:
…
int num = 3;
pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;
pthread_t TID1, TID2;
/*线程调用函数*/