多线程的那些事(之数据同步)

来源:互联网 发布:linux 执行脚本 编辑:程序博客网 时间:2024/06/05 04:26

线程同步:是指线程之间所具有的一种制约关系,一个线程的执行依赖于另一个线程的消息,当它没有得到另一个线程的消息时应等待,直到消息到达时才被唤醒

多线程的创建其实十分简单,在windows系统下面有很多函数可以创建多线程,比如说_beginthread。我们可以用它来创建一个简单的多线程代码。

// ThreadDataSync1.cpp : 定义控制台应用程序的入口点。//多线程的那些事(之数据同步1)#include "stdafx.h"#include <Windows.h>#include <process.h>#include <stdio.h>unsigned int val=0;void PrintInfo(void* argv) {    while(1)    {        printf("&val=%x , val=%d\n",&val,val);        val++;        Sleep(1000);    }}int _tmain(int argc, _TCHAR* argv[]){    _beginthread(PrintInfo,0,NULL);    _beginthread(PrintInfo,0,NULL);    while(1)    {        Sleep(1);    }    system("pause");return 0;}

通过上面的示例,我们看到作为共享变量的val事实上是可以被所有的线程访问的。这就是线程数据同步的最大优势——方便,直接。因为线程之间除了堆栈空间不一样之外,代码段和数据段都是在一个空间里的。所以,线程访问公共数据,就可以访问公共数据,没有任何的限制。

当然,事物都有两面性。这种对公共资源的访问模式也会导致问题的——数据不同步了也就是数据被破坏了。它是由于系统CPU时间片分配方式引起的。虽然在某一时刻,只有一个线程占用CPU(单CPU时),但是没有办法知道在什么时候,在什么地方线程被打断,这样如何保护线程之间不破坏彼此的数据就显得格外重要了。解决此问题通常有4中种方法:临界区对象(CriticalSection),互斥量对象(Mutex),信号量对象(Semaphore),事件对象(Event)。