p操作對應着WaitForSingleObject
v操作對應着ReleaseSemaphore
CRITICAL_SECTION就是臨界區,你懂的
寫者寫一次,讀者read1,read2,read3都讀一次之後,write才能再次寫。一下是win32源代碼。例子比較簡單,不過網上現成的例子貌似不太多,要有也是很雜亂的那種,是以寫下來
#include<windows.h>
#include<process.h>
#include<iostream>
using namespace std;
CRITICAL_SECTION cs;
typedef struct{
HANDLE h1;
HANDLE h2;
HANDLE h3;
HANDLE h4;
int a;
}PARAMS,*PPARAMS;
void read1(PVOID pvoid){
while(TRUE){
volatile PPARAMS pparams=(PPARAMS)pvoid;
WaitForSingleObject(pparams->h2,INFINITE);
EnterCriticalSection(&cs);
cout<<"讀線程1開始讀取...\n";
cout<<(pparams->a)<<endl;
LeaveCriticalSection(&cs);
Sleep(1000);
ReleaseSemaphore(pparams->h1,1,NULL);
}
}
void read2(PVOID pvoid){
while(TRUE){
volatile PPARAMS pparams=(PPARAMS)pvoid;
WaitForSingleObject(pparams->h3,INFINITE);
EnterCriticalSection(&cs);
cout<<"讀線程2開始讀取...\n";
cout<<(pparams->a)<<endl;
LeaveCriticalSection(&cs);
Sleep(1000);
ReleaseSemaphore(pparams->h1,1,NULL);
}
}
void read3(PVOID pvoid){
while(TRUE){
volatile PPARAMS pparams=(PPARAMS)pvoid;
WaitForSingleObject(pparams->h4,INFINITE);
EnterCriticalSection(&cs);
cout<<"讀線程3開始讀取...\n";
cout<<(pparams->a)<<endl;
LeaveCriticalSection(&cs);
Sleep(1000);
ReleaseSemaphore(pparams->h1,1,NULL);
}
}
void write(PVOID pvoid){
while(TRUE){
volatile PPARAMS pparams=(PPARAMS)pvoid;
WaitForSingleObject(pparams->h1,INFINITE);
WaitForSingleObject(pparams->h1,INFINITE);
WaitForSingleObject(pparams->h1,INFINITE);
cout<<"=================\n";
cout<<"寫線程開始寫入...\n";
pparams->a=rand()%256;
cout<<"寫入"<<(pparams->a)<<endl;
ReleaseSemaphore(pparams->h2,1,NULL);
ReleaseSemaphore(pparams->h3,1,NULL);
ReleaseSemaphore(pparams->h4,1,NULL);
}
}
int main(){
PARAMS params;
params.h1=CreateSemaphore(NULL,3,3,NULL);
params.h2=CreateSemaphore(NULL,0,1,NULL);
params.h3=CreateSemaphore(NULL,0,1,NULL);
params.h4=CreateSemaphore(NULL,0,1,NULL);
InitializeCriticalSection(&cs);
_beginthread(read1,0,¶ms);
_beginthread(read2,0,¶ms);
_beginthread(read3,0,¶ms);
_beginthread(write,0,¶ms);
// HANDLE hEvent;
// hEvent=CreateEvent(NULL,FALSE,FALSE,NULL);
// WaitForSingleObject(hEvent,INFINITE);
int a;cin>>a;
DeleteCriticalSection(&cs);
return 0;
}