MFC_临界区_打印字符串_2线程

#include <stdio.h>
#include <afxmt.h>
DWORD WINAPI myfun1(LPVOID lpParameter);	//声明线程函数
DWORD WINAPI myfun2(LPVOID lpParameter);
CCriticalSection m_Sec;									//定义全局变量m_Sec
int a=0;
												//定义全局变量a
int main()
{	
	HANDLE h1,h2;											//定义线程句柄
	h1=::CreateThread(NULL,0,myfun1,NULL,0,NULL);			//创建线程1
	printf("线程1开始运行!\r\n");
	h2=::CreateThread(NULL,0,myfun2,NULL,0,NULL);			//创建线程2
	printf("线程2开始运行!\r\n");
	::CloseHandle(h1);										//关闭线程句柄对象
	::CloseHandle(h2);
	::Sleep(100000);											//程序睡眠10秒
	return 0;
}
DWORD WINAPI myfun1(LPVOID lpParameter) 				//线程函数1
{
	while (1)
	{
		m_Sec.Lock();		//锁定临界区	
		for (int i = 0; i < 5; i++)
		{
			a += 1;//变量加1
			printf("线程1---%d\n", a);//输出变量	
		}
		m_Sec.Unlock();								//对临界区进行解锁
		Sleep(1000);
	}

	return 0;
}
DWORD WINAPI myfun2(LPVOID lpParameter) 		//线程函数2
{
	while (1)
	{
		m_Sec.Lock();		//锁定临界区
		for (int i = 0; i < 5; i++)
		{
			a += 1;//变量加1
			printf("线程2---%d\n", a);		//输出变量		
		}
		m_Sec.Unlock();								//对临界区进行解锁
		Sleep(1000);
	}
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值