vc多线程vc如何多线程编程

vc多线程  时间:2021-08-18  阅读:()

vc多线程修改同一个全局变量,如何加锁

CRITICAL_SECTION cs; // 全局变量 ::InitializeCriticalSection( & cs); // 初始化锁 ::EnterCriticalSection( & cs); 获得锁 ...... ::LeaveCriticalSection( & cs); // 释放锁 ...... ::DeleteCriticalSection( & cs); // 删除锁 ------解决方案--------------------------------------------------------探讨引用:C/C++ codeCRITICAL_SECTION cs; // 全局变量

如何在windows系统上用c++创建多线程

//?TS2.cpp?:?Defines?the?entry?point?for?the?console?application. // #include?"stdafx.h" #include? #include? #include? void?gotoxy(int?a,?int?b) { ????cout<<"gotoxy関数実行成功!!!"<VC中怎么用多线程画图,不显示画图过程啊,我是新手如果用DC的话,也就是设备内容(CreateCompatibleDC),多线程绘制意义不大。

因为DC的缘故,线程必须要做同步,所以最终的效率不会有多大提升,也就是多一个系统调度时间片而已。

因此, 1、如果在CreateCompatibleDC的情况下必须使用多线程的话,那就是要用系统临界区对全局DC(绘图设备内容)做原子访问限制。

具体可以搜索一下“系统临界区”。

2、如果不一定用何种绘图手段,需要多线程来大幅度提升效率的话,我推荐采用定义全局画布缓冲区,然后对每一个绘图线程分配其各自的Rect,用以绘制,最后用DirectDraw或Direct3D将缓冲区复制到显卡即可。

这样效率是最高的。

例如: unsigned char g_ucGraphMemory[1024*768*4]; //全局画布缓冲区,1024x768大小,32位色(A8R8G8B8) typedef struct { unsigned char *ptrOffset; unsigned long dwLength; } DrawRect; // 每个线程需要画的区域 int main() { /* 将整个画布(g_ucGraphMemory)分割成4块区域 */ DrawRect mRect[4]; mRect[0].ptrOffset = g_ucGraphMemory; mRect[1].ptrOffset = g_ucGraphMemory + (1024 * 768); mRect[2].ptrOffset = g_ucGraphMemory + ((1024 * 768) * 2); mRect[3].ptrOffset = g_ucGraphMemory + ((1024 * 768) * 3); mRect[0].dwLength = 1024 * 768; mRect[1].dwLength = 1024 * 768; mRect[2].dwLength = 1024 * 768; mRect[3].dwLength = 1024 * 768; /***********************************************/ CreateThread(..., Thread1, &mRect[0]); // 创建绘图线程1 CreateThread(..., Thread2, &mRect[1]); // 创建绘图线程2 CreateThread(..., Thread3, &mRect[2]); // 创建绘图线程3 CreateThread(..., Thread4, &mRect[3]); // 创建绘图线程4 ...... WaitForSingleObject(); // 等待线程绘图完毕 Direct3DCreate9(); // 创建D3D设备 .... CreateTexture(); // 创建纹理 .... CreateVertexBuffer(); // 创建顶点缓冲区 .... LockRect(); // 锁定纹理区域 memcpy(); // 把g_ucGraphMemory复制到D3D纹理缓冲区内 .... DrawPrimitive(); // 把纹理贴到多边形上 .... Present(); // 显卡绘图 .... } // 绘图线程1 DWORD WINAPI Thread1(DrawRect *ptrRect) { ptrRect->ptrOffset; // 这个便是此线程需要绘制的区域始地址 ptrRect->dwLength ; // 这个是此线程需要绘制的区域大小 ..... // 这里可以使用像素填充法、向量、GDI复制到内存区等手段进行绘制 ..... // 通知主线程绘图完毕 } // 绘图线程2 DWORD WINAPI Thread2(DrawRect *ptrRect) { .... } // 绘图线程3 DWORD WINAPI Thread3(DrawRect *ptrRect) { .... } // 绘图线程4 DWORD WINAPI Thread4(DrawRect *ptrRect) { .... } 以上只是一个多线程分块内存缓冲区绘图的流程例子,实际代码要多一些。

此处主要表达分块的思想和主线程等待分线程绘图并进行显示的流程。

其中分块过程是为了简单,所以采用数组直接分段。

实际中需要按照应用场合进行调整,如按行像素分块、按列像素分块、按矩形像素分块等。

vc如何多线程编程

在VC中可以调用MFC函数AfxBeginThread,创建线程。

线程做什么,怎么做就得看你自己的设计了。

贴一段MSDN里的代码: Visual C++ Copy Code class CSockThread : public CWinThread { public: SOCKET m_hConnected; protected: CChatSocket m_sConnected; // remainder of class declaration omitted. Visual C++ Copy Code BOOL CSockThread::InitInstance() { // Attach the socket object to the socket handle // in the context of this thread. m_sConnected.Attach(m_hConnected); m_hConnected = NULL; return TRUE; } Visual C++ Copy Code // This listening socket has been constructed // in the primary thread. void CListeningSocket::ept(int nErrorCode) { UNREFERENCED_PARAMETER(nErrorCode); // This CSocket object is used just temporarily // to ept the ing connection. CSocket sConnected; ept(sConnected); // Start the other thread. CSockThread* pSockThread = (CSockThread*)AfxBeginThread( RUNTIME_CLASS(CSockThread), THREAD_PRIORITY_NORMAL, 0, CREATE_SUSPENDED); if (NULL != pSockThread) { // Detach the newly epted socket and save // the SOCKET handle in our new thread object. // After detaching it, it should no longer be // used in the context of this thread. pSockThread->m_hConnected = sConnected.Detach(); pSockThread->ResumeThread(); } }

RAKsmart:美国洛杉矶独服,E3处理器/16G/1TB,$76.77/月;美国/香港/日本/韩国站群服务器,自带5+253个IPv4

RAKsmart怎么样?RAKsmart机房即日起开始针对洛杉矶机房的独立服务器进行特别促销活动:低至$76.77/月,最低100Mbps带宽,最高10Gbps带宽,优化线路,不限制流量,具体包括有:常规服务器、站群服务器、10G大带宽服务器、整机机柜托管。活动截止6月30日结束。RAKsmart,美国华人老牌机房,专注于圣何塞服务器,有VPS、独立服务器等。支持PayPal、支付宝付款。点击直达...

RAKsmart美国洛杉矶独立服务器 E3-1230 16GB内存 限时促销月$76

RAKsmart 商家我们应该较多的熟悉的,主营独立服务器和站群服务器业务。从去年开始有陆续的新增多个机房,包含韩国、日本、中国香港等。虽然他们家也有VPS主机,但是好像不是特别的重视,价格上特价的时候也是比较便宜的1.99美元月付(年中活动有促销)。不过他们的重点还是独立服务器,毕竟在这个产业中利润率较大。正如上面的Megalayer商家的美国服务器活动,这个同学有需要独立服务器,这里我一并整理...

tmhhost:全场VPS低至6.4折,香港BGP200M日本软银美国cn2 gia 200G高防美国三网cn2 gia韩国CN2

tmhhost放出了2021年的端午佳节+618年中大促的优惠活动:日本软银、洛杉矶200G高防cn2 gia、洛杉矶三网cn2 gia、香港200M直连BGP、韩国cn2,全都是高端优化线路,所有这些VPS直接8折,部分已经做了季付8折然后再在此基础上继续8折(也就是6.4折)。 官方网站:https://www.tmhhost.com 香港BGP线路VPS ,200M带宽 200M带...

vc多线程为你推荐
getsockopt提示出现这个怎么办?电子听诊器怎样选择听诊器最好的视频播放器现在最好的播放器 是什么呀蓝牙开发蓝牙技术到底是指什么?数据管理制度简述系统运行管理制度的主要内容武汉教育云平台武汉天喻教育科技有限公司怎么样?微信收费微信提现收费是怎么计算的 从什么时候开始收费眼镜片品牌什么品牌的近视眼镜片好移动硬盘提示格式化移动硬盘显示需要格式化怎么修复网站维护收费网站维护费用,一年要多少钱
虚拟空间免费试用 域名论坛 中国万网域名注册 政务和公益机构域名注册管理中心 双线主机租用 域名解析文件 a5域名交易 主机 美国翻墙 rackspace kddi 新世界电讯 idc资讯 根服务器 cloudlink 四川电信商城 上海电信测速 论坛主机 注册阿里云邮箱 金主 更多