互斥锁的主要目的是防止多个线程同时访问同一资源。为什么不允许多线程同时访问同一资源呢。首先我们要对程序在运算的过程。假如计程序要对一个变量执行自加运算,那么过程是:首先程序到这个变量的内存中拷贝走变量值,然后交给cpu,cpu计算后将计算结果返回,然后重新保存在原来的位置,从而实现了这个变量的自加运算。打个比方,有一个变量“tmp”,它当前的值为5,两个线程几乎同时要访问这个变量。线程a想执行tmp++,线程b也想执行tmp++,线程a首先获取到了tmp的值发送给了cpu进行计算,而没等cpu计算完成将计算结果保存在tmp的内存中时,线程b来了,线程b也拷贝走了tmp的值,由于线程a的计算还没完成,所以此时tmp的值仍然是5。线程a运算结束后将结果保存在tmp的内存中,值为6。线程b运算的结果也是6,线程b也将结果保存在了tmp的内存中,那么此时tmp的值就是6。而我们的期望值却是7。所以我们要想办法,设置线程a访问tmp的时候,线程b不可以访问。就不会有这个问题了。这就引入了互斥锁的概念。
下面一段代码是在vs2013中创建的,使用了pthread中的互斥锁,因为linux中多线程就是使用pthread,这样的代码可移植性强,在运行这段代码前,您需要先学习一下在Windows上如何使用pthread,其实很简单,百度一下。
这段代码中写了两个循环,来对比同样的操作加互斥锁和不加互斥锁的区别。
我们创建了很多线程,这些线程都会访问变量num,将这些线程平均分成两部分,一部分执行自加运算,另一部分执行自减运算。两部分线程的数量一样多,每个线程执行自