天天看點

win32 pv操作 讀者寫者問題

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;
}
           

繼續閱讀