本文实例分析了C++线程同步问题,分享给大家供大家参考。具体分析如下:
该实例设置全局变量g_bContinue,在主线程中设置全局变量g_bContinue,工作线程检测该全局变量,实现主线程控制工作线程的目的。
打印出的g_cnt1与g_cnt2的数值不同,是因为线程调试时时间片的切换。
具体代码如下:
// countError.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <Windows.h>
DWORD g_cnt1;
DWORD g_cnt2;
BOOL g_bContinue = TRUE;
DWORD WINAPI ThreadProc(__in LPVOID lpParameter)
{
while(g_bContinue)
{
g_cnt1++;
g_cnt2++;
}
return 0;
}
int _tmain(int argc, _TCHAR* argv[])
{
HANDLE hThread[2];
g_cnt1 = g_cnt2 = 0;
hThread[0] = ::CreateThread(NULL, 0, ThreadProc, NULL, 0, NULL);
hThread[1] = ::CreateThread(NULL, 0, ThreadProc, NULL, 0, NULL);
Sleep(1000);
g_bContinue = FALSE;
::WaitForMultipleObjects(2, hThread, TRUE, INFINITE);
printf("g_cnt1=%d\n",g_cnt1);
printf("g_cnt2=%d\n",g_cnt2);
::CloseHandle(hThread[0]);
::CloseHandle(hThread[1]);
return 0;
}
希望本文所述对大家的C++程序设计有所帮助。
您可能感兴趣的文章:C++实现多线程查找文件实例C++线程池的简单实现方法c++版线程池和任务池示例C/C++中退出线程的四种解决方法C/C++ 多线程的学习心得总结解析C/C++中如何终止线程的运行C++开发:为什么多线程读写shared_ptr要加锁的详细介绍C++进程共享数据封装成类实例C++选择文件夹代码的封装C++动态数组类的封装实例C++内核对象封装单实例启动程序的类C++封装线程类的实现方法