说明:我讲解这些,是站在各位对线程已经有了一定的认识,比如说理解什么是同步或异步之类的概率,如果要把这些讲清楚,实现篇幅太多,也没有这个精力。
废话不多说,我们切入正题。
我们先看一个问题:
我启动两个线程,两个线程对全局变量都在加1,每个线程循环5000,结果应该是5000*2=10000才对啊,可事实如此吗?
源码下载:http://download.csdn.net/detail/jefry_xdz/4246149
这里面的全部变量counter是两个线程共享的,两个线程访问很容易冲突,这么解决呢?
Mutex此时可以闪亮登场了,呵呵
锁的初始化与销毁
#include <pthread.h>
int pthread_mutex_destroy(pthread_mutex_t *mutex);
int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_init对Mutex初始化,attr设为NULL则表示缺省值。用pthread_mutex_init可以用pthread_mutex_destroy来销毁,如果变量时全局的,也可以用pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;来初始化。相当于pthread_mutex_init的attr为NULL。
加锁与解锁:
#include <pthread.h>
int pthread_mutex_lock(pthread_mutex_t *mutex); //获取锁,如果锁非空闲则阻塞。
int pthread_mutex_trylock(pthread_mutex_t *mutex); //获取锁,如果锁非空闲不阻塞。
int pthread_mutex_unlock(pthread_mutex_t *mutex); //释放锁
请看下面演示,问题得以解决,大吼一下……
源码下载:
http://download.csdn.net/detail/jefry_xdz/4246149