[C++] socket - 6 [API互斥事件对象实现线程同步]

简介:


 

 

复制代码
/*API互斥事件对象实现线程同步*/
#include<windows.h>
#include<stdio.h>
DWORD WINAPI myfun1(LPVOID lpParameter);//声明线程函数
DWORD WINAPI myfun2(LPVOID lpParameter);
static int a=0;
HANDLE hmutex;//互斥事件对象
int main()
{
    HANDLE h1,h2;//定义句柄变量
    hmutex=::CreateMutex(NULL,FALSE,NULL);//创建互斥事件并返回其句柄
    h1=::CreateThread(NULL,0,myfun1,NULL,0,NULL);//创建线程1
    printf("线程1开始运行!\r\n");
    h2=::CreateThread(NULL,0,myfun2,NULL,0,NULL);//创建线程2
    printf("线程2开始运行!\t\n");
    ::CloseHandle(h1);//关闭线程句柄对象
    ::CloseHandle(h2);
    ::Sleep(100000);
    return 0;
}
DWORD WINAPI myfun1(LPVOID lpParameter)//线程函数
{
    while(1)
    {
        ::WaitForSingleObject(hmutex,INFINITE);//请求互斥事件
        if(a<100)
        {
            ::Sleep(1000);
            a+=1;
            printf("线程1:%d\r\n",a);
            ::ReleaseMutex(hmutex);
        }
        else
        {
            ::ReleaseMutex(hmutex);//释放互斥事件句柄
            break;
        }
    }
    return 0;
}
DWORD WINAPI myfun2(LPVOID lpParameter)
{
    while(1)
    {
        ::WaitForSingleObject(hmutex,INFINITE);//请求事件对象
        if(a<100)
        {
            ::Sleep(1000);
            a+=1;
            printf("线程2:%d\r\n",a);
            ::ReleaseMutex(hmutex);
        }
        else
        {
            ::ReleaseMutex(hmutex);
            break;
        }
    }
    return 0;
}
复制代码


相关文章
|
14天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
30天前
|
API 数据库 C语言
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
169 0
|
1月前
|
存储 前端开发 Java
【C++ 多线程 】C++并发编程:精细控制数据打印顺序的策略
【C++ 多线程 】C++并发编程:精细控制数据打印顺序的策略
45 1
|
1月前
|
数据可视化 关系型数据库 编译器
【C/C++ 单线程性能分析工具 Gprof】 GNU的C/C++ 性能分析工具 Gprof 使用全面指南
【C/C++ 单线程性能分析工具 Gprof】 GNU的C/C++ 性能分析工具 Gprof 使用全面指南
108 2
|
1月前
|
存储 前端开发 算法
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析(一)
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析
45 0
|
29天前
|
存储 算法 Java
【C/C++ 线程池设计思路】 深入探索线程池设计:任务历史记录的高效管理策略
【C/C++ 线程池设计思路】 深入探索线程池设计:任务历史记录的高效管理策略
72 0
|
1月前
|
消息中间件 Linux 调度
【Linux 进程/线程状态 】深入理解Linux C++中的进程/线程状态:阻塞,休眠,僵死
【Linux 进程/线程状态 】深入理解Linux C++中的进程/线程状态:阻塞,休眠,僵死
67 0
|
1月前
|
存储 并行计算 Java
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析(二)
C++线程 并发编程:std::thread、std::sync与std::packaged_task深度解析
64 0
|
29天前
|
安全 Java 调度
【C/C++ 线程池设计思路 】设计与实现支持优先级任务的C++线程池 简要介绍
【C/C++ 线程池设计思路 】设计与实现支持优先级任务的C++线程池 简要介绍
44 2
|
29天前
|
Linux API C++
【C++ 线程包裹类设计】跨平台C++线程包装类:属性设置与平台差异的全面探讨
【C++ 线程包裹类设计】跨平台C++线程包装类:属性设置与平台差异的全面探讨
51 2