一、线程同步
在一般情况下,创建一个线程是不能提高程序的执行效率的,所以要创建多个线程。但是多个线程同时运行的时候可能调用线程函数,在多个线程同时对同一个内存地址进行写入,由于CPU时间调度上的问题,写入数据会被多次的覆盖,这时会出现程序混乱的问题,无法得到原来需要的数据,所以就要使线程同步。
线程同步:即当有一个线程在对内存进行操作时,其他线程都不可以对这个内存地址进行操作,直到该线程完成操作, 其他线程才能对该内存地址进行操作,而其他线程又处于等待状态
二、互斥量mutex
1、基本概念
要解决上面的问题,可以引入互斥量,在解决进程间通信所产生的冲突问题时,有一种机制就是信号量,互斥量和信号量基本上是相同的概念,就是当一个线程在访问某个数据时可以加上一把互斥锁,当别的线程也要访问这个数据时就要请求加锁,而此时锁已经被别的线程申请要过去了,那这个线程就需要等待,直到有锁可用才能再加锁访问数据,如此一来,就可以将“读取—执行—写入”这三部化成一个原子性的问题,要么都执行,要么一步也不执行,不会被中途打断。
2、互斥量的接口
(1)初始化互斥量
方法1:静态分配
pthread_mutex mutex=PTHREAD_MUTEX_INITIALIZER
方法2:动态分配
mutex:要初始化的互斥量
attr:NULL
(2)互斥量销毁
销毁互斥量需要注意:
(1)使用PTHREAD_ MUTEX_ INITIALIZER初始化的互斥量不需要销毁
(2)不要销毁一个已经加锁的互斥量
(3)已经销毁的互斥量,要确保后面不会有线程再尝试加锁