windows C++ 多任务并发执行设计

简介: windows C++ 多任务并发执行设计

1、问题描述

如图:image.png

(1)服务端负责下发任务;且每次下发一个任务,下发任务个数不固定(通过下发界面勾选下发),但总个数<=4个。

(2)客户端负责接收任务,接收任务后要循环执行,除非接收到停止指令后停止执行。

指令类型分为:

1)心跳指令——用于保活连接;

2)任务开始指令——用于开始执行任务;

3)任务中止指令——用于结束任务;


2、设计详解

(1)客户端要并发运行,且会调用相同接口传递不同参数实现,所以必须进行多线程同步。

线程数目由客户端Socket接收信息解析后而定,但总数目会<=4,未来可能会拓展。

所以,此处使用Semaphore信号量进行同步。


(2)相同代码段,为避免访问冲突,导致异常。需要使用“关键代码段”Critical Section进行互斥访问。


3、模拟代码


#include <stdio.h>

#include <process.h>

#include <windows.h>


long g_nNum = 0;

unsigned int __stdcall Fun(void *pPM);

const int g_iMaxThreadCnt = 4; //客户端线程个数


//信号量与关键段

HANDLE g_hThreadParam;

CRITICAL_SECTION g_csThreadCode;


unsigned int __stdcall Fun(void *pPM)

{

int nThreadNum = *(int *)pPM;

EnterCriticalSection(&g_csThreadCode);

while(1)

{

++g_nNum;

printf("线程No为%d 全局资源值为%d\n", nThreadNum, g_nNum);

ReleaseSemaphore(g_hThreadParam, 1, NULL);//信号量++

LeaveCriticalSection(&g_csThreadCode);


Sleep(1000);//模拟执行

}


return 0;

}


int TestMyThread()

{

//初始化信号量和关键段

//当前0个资源,最大允许1个同时访问

g_hThreadParam = CreateSemaphore(NULL, 0, 1, NULL);

InitializeCriticalSection(&g_csThreadCode);


HANDLE hThread[g_iMaxThreadCnt] = {NULL};

g_nNum = 0;

int i = 0;

while (i < g_iMaxThreadCnt)

{

hThread[i] = (HANDLE)_beginthreadex(NULL, 0, Fun, &i, 0, NULL);

WaitForSingleObject(g_hThreadParam, INFINITE);//等待信号量>0

++i;

}

//等待所有线程结束

WaitForMultipleObjects(g_iMaxThreadCnt, hThread, TRUE, INFINITE);


//销毁信号量和关键段

DeleteCriticalSection(&g_csThreadCode);

CloseHandle(g_hThreadParam);

for (i = 0; i < g_iMaxThreadCnt; i++)

{

CloseHandle(hThread[i]);

}

return 0;

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

image.png

4、小结

1)实际项目中要比这复杂很多,涉及socket数据接收与解析、循环执行等。

循环执行在线程内部实现比较好,这样不必循环调用线程,产生不必要的开销。

2)心中要先有框图内容,并思考如何执行,多测试以验证执行结果和预期、编码是否完全一致。

3)API经常不用会不熟悉,一定要MSDN清楚每个字段的切实含义,避免“自以为是”,影响大局。


相关文章
|
4月前
|
缓存 负载均衡 Java
c++写高性能的任务流线程池(万字详解!)
本文介绍了一种高性能的任务流线程池设计,涵盖多种优化机制。首先介绍了Work Steal机制,通过任务偷窃提高资源利用率。接着讨论了优先级任务,使不同优先级的任务得到合理调度。然后提出了缓存机制,通过环形缓存队列提升程序负载能力。Local Thread机制则通过预先创建线程减少创建和销毁线程的开销。Lock Free机制进一步减少了锁的竞争。容量动态调整机制根据任务负载动态调整线程数量。批量处理机制提高了任务处理效率。此外,还介绍了负载均衡、避免等待、预测优化、减少复制等策略。最后,任务组的设计便于管理和复用多任务。整体设计旨在提升线程池的性能和稳定性。
122 5
|
5月前
|
并行计算 安全 调度
C++ 11新特性之并发
C++ 11新特性之并发
109 0
|
6月前
|
Windows Python
【Azure 批处理 Azure Batch】在Azure Batch中如何通过开始任务自动安装第三方依赖的一些软件(Windows环境)
【Azure 批处理 Azure Batch】在Azure Batch中如何通过开始任务自动安装第三方依赖的一些软件(Windows环境)
|
6月前
|
安全 C++ Windows
Windows下C++使用gRPC(Qt和VS,含文件包和使用方法)
Windows下C++使用gRPC(Qt和VS,含文件包和使用方法)
|
7月前
|
JavaScript IDE 持续交付
阿里云云效产品使用合集之如何配置 Node.js构建任务让其在Windows环境中进行
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
7月前
|
安全 程序员 C++
C++一分钟之-C++中的并发容器
【7月更文挑战第17天】C++11引入并发容器,如`std::shared_mutex`、`std::atomic`和线程安全的集合,以解决多线程中的数据竞争和死锁。常见问题包括原子操作的误用、锁的不当使用和迭代器失效。避免陷阱的关键在于正确使用原子操作、一致的锁管理以及处理迭代器失效。通过示例展示了如何安全地使用这些工具来提升并发编程的安全性和效率。
98 1
|
8月前
|
安全 API C++
逆向学习Windows篇:C++中多线程的使用和回调函数的实现
逆向学习Windows篇:C++中多线程的使用和回调函数的实现
280 0
|
8月前
|
C++ UED 开发者
逆向学习 MFC 篇:视图分割和在 C++ 的 Windows 窗口程序中添加图标的方法
逆向学习 MFC 篇:视图分割和在 C++ 的 Windows 窗口程序中添加图标的方法
110 0
|
9月前
|
安全 Go 对象存储
C++多线程编程:并发与同步的实战应用
本文介绍了C++中的多线程编程,包括基础知识和实战应用。C++借助`&lt;thread&gt;`库支持多线程,通过`std::thread`创建线程执行任务。文章探讨了并发与同步的概念,如互斥锁(Mutex)用于保护共享资源,条件变量(Condition Variable)协调线程等待与通知,以及原子操作(Atomic Operations)保证线程安全。实战部分展示了如何使用多线程进行并发计算,利用`std::async`实现异步任务并获取结果。多线程编程能提高效率,但也需注意数据竞争和同步问题,以确保程序的正确性。
|
9月前
|
安全 C++
C++多线程编程:并发与同步
C++多线程编程:并发与同步
64 0