windows 线程同步的4种方法

1.     互斥信号量

   #include <windows.h>
#include <iostream>
using namespace std;

DWORD WINAPI Fun1Proc(LPVOID param);
DWORD WINAPI Fun2Proc(LPVOID param);

int time 0;
HANDLE Mutex;

void main()
{
    HANDLE thread1,thread2;
    thread1 CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);
    thread2 CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);
    CloseHandle(thread1);
    CloseHandle(thread2);
   
 Mutex CreateMutex(NULL,FALSE,NULL);
    cout << "
运行主线程!" << endl;
    Sleep(4000);
}

DWORD WINAPI Fun1Proc(LPVOID param)
{
    
while(1) {
        
WaitForSingleObject(Mutex,INFINITE);
        if(time <= 20) {
            Sleep(1);
            cout << "
线程1运行第<< time++ << "<< endl;
        }
        
else
            
break;
      
  ReleaseMutex(Mutex);
    }
    
return 0;
}

DWORD WINAPI Fun2Proc(LPVOID param)
{
    
while(1) {
       
 WaitForSingleObject(Mutex,INFINITE);
        if(time <= 20) {
            Sleep(1);
            cout << "
线程2运行第<< time++ << "<< endl;
        }
        
else
            
break;
      
  ReleaseMutex(Mutex);
    }
    
return 0;
}

2. 基于事件的同步方法

#include <windows.h>
#include <iostream>
using namespace std;

DWORD WINAPI Fun1Proc(LPVOID param);
DWORD WINAPI Fun2Proc(LPVOID Param);

int time;
HANDLE events;

void main()
{
    HANDLE thread1,thread2;
    thread1 CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);
    thread2 CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);
    CloseHandle(thread1);
    CloseHandle(thread2);
    
events CreateEvent(NULL,FALSE,FALSE,NULL);
    SetEvent(events);
    Sleep(4000);
    CloseHandle(events);
}
DWORD WINAPI Fun1Proc(LPVOID param)
{
    
while(1) {
        
WaitForSingleObject(events,INFINITE);
        if(time <= 20) {
            Sleep(1);
            cout << "
线程1运行第<< time++ << "<< endl;
        }
        
else
            
break;
       
 SetEvent(events);
    }
    
return 0;
}

DWORD WINAPI Fun2Proc(LPVOID param)
{
    
while(1) {
      
  WaitForSingleObject(events,INFINITE);
        if(time <= 20) {
            Sleep(1);
            cout << "
线程2运行第<< time++ << "<< endl;
        }
        
else
            
break;
        
SetEvent(events);
    }
    
return 0;
}

3.基于临界区的进程同步方法

#include <windows.h>
#include <iostream>
using namespace std;

DWORD WINAPI Fun1Proc(LPVOID param);
DWORD WINAPI Fun2Proc(LPVOID param);

int time 0;
CRITICAL_SECTION critical;

void main()
{
    HANDLE thread1,thread2;
    thread1 CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);
    thread2 CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);
    CloseHandle(thread1);
    CloseHandle(thread2);

    
InitializeCriticalSection(&critical);
    Sleep(4000);
  
  DeleteCriticalSection(&critical);
}

DWORD WINAPI Fun1Proc(LPVOID param)
{
    
while(1)
    
 {
       
 EnterCriticalSection(&critical);
        if(time <= 20)
        
 {
            Sleep(1);
            cout << "
子线程1<< time ++ << ""<< endl;
        }
        
else
            
break;
        
LeaveCriticalSection(&critical);
    }
    
return 0;
}

DWORD WINAPI Fun2Proc(LPVOID param)
{
    
while(1)
    
 {
       
 EnterCriticalSection(&critical);
        if(time <= 20)
        
 {
            Sleep(1);
            cout << "
子线程2<< time ++ << "<< endl;
        }
        
else
            
break;
      
  LeaveCriticalSection(&critical);
    }
    
return 0;
}

4. 基于信号量的方法

#include <windows.h>
#include <iostream>
using namespace std;

DWORD WINAPI Fun1Proc(LPVOID param);
DWORD WINAPI Fun2Proc(LPVOID param);

int time 0;
HANDLE sema;

void main()

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值