线程同步:是指线程之间所具有的一种制约关系,一个线程的执行依赖于另一个线程的消息,当它没有得到另一个线程的消息时应等待,直到消息到达时才被唤醒
多线程的创建其实十分简单,在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)。