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

image.png

4、小结

1)实际项目中要比这复杂很多,涉及socket数据接收与解析、循环执行等。
循环执行在线程内部实现比较好,这样不必循环调用线程,产生不必要的开销。
2)心中要先有框图内容,并思考如何执行,多测试以验证执行结果和预期、编码是否完全一致。
3)API经常不用会不熟悉,一定要MSDN清楚每个字段的切实含义,避免“自以为是”,影响大局。

2015-8-30 am11:58 整理于家中床前

作者:铭毅天下
转载请标明出处,原文地址:http://blog.csdn.net/laoyang360/article/details/48103473

如果感觉本文对您有帮助,请点击‘顶’支持一下,您的支持是我坚持写作最大的动力,谢谢!

作者:铭毅天下
来源:CSDN
原文:https://blog.csdn.net/laoyang360/article/details/48103473
版权声明:本文为博主原创文章,转载请附上博文链接!

相关文章
|
6月前
|
存储 监控 算法
【C++ 软件设计思路】高效管理历史任务记录:内存与磁盘结合的策略解析
【C++ 软件设计思路】高效管理历史任务记录:内存与磁盘结合的策略解析
121 0
|
6月前
|
人工智能 机器人 C++
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
137 0
|
6月前
|
关系型数据库 数据库 C++
【C++】Windows使用Visual Studio C++链接云数据库PostgreSQL(沉浸式老爷教学)
【C++】Windows使用Visual Studio C++链接云数据库PostgreSQL(沉浸式老爷教学)
|
6月前
|
人工智能 机器人 编译器
【C++】Windows端VS code中运行CMake工程(手把手教学)
【C++】Windows端VS code中运行CMake工程(手把手教学)
386 0
|
1月前
|
缓存 负载均衡 Java
c++写高性能的任务流线程池(万字详解!)
本文介绍了一种高性能的任务流线程池设计,涵盖多种优化机制。首先介绍了Work Steal机制,通过任务偷窃提高资源利用率。接着讨论了优先级任务,使不同优先级的任务得到合理调度。然后提出了缓存机制,通过环形缓存队列提升程序负载能力。Local Thread机制则通过预先创建线程减少创建和销毁线程的开销。Lock Free机制进一步减少了锁的竞争。容量动态调整机制根据任务负载动态调整线程数量。批量处理机制提高了任务处理效率。此外,还介绍了负载均衡、避免等待、预测优化、减少复制等策略。最后,任务组的设计便于管理和复用多任务。整体设计旨在提升线程池的性能和稳定性。
78 5
|
2月前
|
并行计算 安全 调度
C++ 11新特性之并发
C++ 11新特性之并发
82 0
|
6月前
|
存储 算法 Java
【C/C++ 线程池设计思路】 深入探索线程池设计:任务历史记录的高效管理策略
【C/C++ 线程池设计思路】 深入探索线程池设计:任务历史记录的高效管理策略
173 0
|
3月前
|
安全 C++ Windows
Windows下C++使用gRPC(Qt和VS,含文件包和使用方法)
Windows下C++使用gRPC(Qt和VS,含文件包和使用方法)
|
4月前
|
安全 程序员 C++
C++一分钟之-C++中的并发容器
【7月更文挑战第17天】C++11引入并发容器,如`std::shared_mutex`、`std::atomic`和线程安全的集合,以解决多线程中的数据竞争和死锁。常见问题包括原子操作的误用、锁的不当使用和迭代器失效。避免陷阱的关键在于正确使用原子操作、一致的锁管理以及处理迭代器失效。通过示例展示了如何安全地使用这些工具来提升并发编程的安全性和效率。
62 1
|
5月前
|
安全 API C++
逆向学习Windows篇:C++中多线程的使用和回调函数的实现
逆向学习Windows篇:C++中多线程的使用和回调函数的实现
184 0
下一篇
无影云桌面