关键代码段
关键代码段,也称为临界区,工作在用户方式下。它是指一个小的代码段,在代码能够执行前,它必须独占对某些资源的访问权。
主要函数
InitializeCriticalSection();--初始化关键代码段
EnterCriticalSection();--进入关键代码段
LeaveCriticalSection();--离开关键代码段
DeleteCriticalSection();--释放关键代码段对象
例子
#include "stdafx.h"
#include <windows.h>
#include <cstdio>
#include <conio.h>
CRITICAL_SECTION g_cs;
int tickets =100;
DWORD WINAPI Fun1Proc1(LPVOID lpParameter)
{
while(1)
{
EnterCriticalSection(&g_cs);
if(tickets>0)
{
printf("thread1 sell ticket:%d\n",tickets--);
LeaveCriticalSection(&g_cs);
Sleep(1000); //不加上该句代码,会出现线程1一直独占临界区资源,同时Sleep()函数的参数值过小,可能会出现线程1、线程2不是交替出现的情况
}
else
{
LeaveCriticalSection(&g_cs);
break;
}
}
return 0;
}
DWORD WINAPI Fun1Proc2(LPVOID lpParameter)
{
while(1)
{
EnterCriticalSection(&g_cs);
if(tickets>0)
{
printf("thread2 sell ticket:%d\n",tickets--);
LeaveCriticalSection(&g_cs);
Sleep(1000);
}
else
{
LeaveCriticalSection(&g_cs);
break;
}
}
return 0;
}
#include <windows.h>
#include <cstdio>
#include <conio.h>
CRITICAL_SECTION g_cs;
int tickets =100;
DWORD WINAPI Fun1Proc1(LPVOID lpParameter)
{
while(1)
{
EnterCriticalSection(&g_cs);
if(tickets>0)
{
printf("thread1 sell ticket:%d\n",tickets--);
LeaveCriticalSection(&g_cs);
Sleep(1000); //不加上该句代码,会出现线程1一直独占临界区资源,同时Sleep()函数的参数值过小,可能会出现线程1、线程2不是交替出现的情况
}
else
{
LeaveCriticalSection(&g_cs);
break;
}
}
return 0;
}
DWORD WINAPI Fun1Proc2(LPVOID lpParameter)
{
while(1)
{
EnterCriticalSection(&g_cs);
if(tickets>0)
{
printf("thread2 sell ticket:%d\n",tickets--);
LeaveCriticalSection(&g_cs);
Sleep(1000);
}
else
{
LeaveCriticalSection(&g_cs);
break;
}
}
return 0;
}
int _tmain(int argc, _TCHAR* argv[])
{
HANDLE hThread1,hThread2;
//初始化关键代码段
InitializeCriticalSection(&g_cs);
//创建线程
hThread1=CreateThread(NULL,0,Fun1Proc1,NULL,0,NULL);
hThread2=CreateThread(NULL,0,Fun1Proc2,NULL,0,NULL);
CloseHandle(hThread1);
CloseHandle(hThread2);
_getch();
printf("exit!\n");
DeleteCriticalSection(&g_cs);
return 0;
}