在VC6.0中多线程编程示例(带同步信号量)

直接上代码:
#include <windows.h>//必要的头文件,使用Windows API函数
#include <stdio.h>

int index = 0;
int tickets = 100;//票数
HANDLE hMutex; //使用全局的互斥对象来保证对同一资源的互斥访问与操作这里是tickets
//线程处理函数原型,形式可从MSDN中拷贝

//线程1 的入口函数

DWORD WINAPI Fun1Proc(LPVOID lpParameter);
DWORD WINAPI Fun2Proc(LPVOID lpParameter);

void main()
{
	HANDLE hThread1;
	DWORD thread1ID;
	//创建线程1
	hThread1 = CreateThread(NULL, 0, Fun1Proc, NULL, 0, &thread1ID);
	HANDLE hThread2;
	DWORD thread2ID;
	//创建线程2
	hThread2 = CreateThread(NULL, 0, Fun2Proc, NULL, 0, &thread2ID);
	CloseHandle(hThread1); //关闭线程的句柄,为什么要关闭?它将线程的使用计数减1
	CloseHandle(hThread2);//这样当线程结束时,线程内核对象被释放,
	//否则只有当进程结束,才释放线程的内核对象hThread1与hThread
    //创建一个互斥对象,如果成功返回互斥对象的句柄,否则返回NULL
	hMutex = CreateMutex(NULL, FALSE, "tickets");
	if (hMutex)	
	{	
		if(ERROR_ALREADY_EXISTS == GetLastError())		
		{		
			puts("only one instance can run!");		
			return;		
		}	
	}
	Sleep(4000);//主线程睡眠4秒钟,给其它线程运行的时间,因为一旦主线程退出则进行退出,其它线程也将退出
}

DWORD WINAPI Fun1Proc(LPVOID lpParameter)
{
	while(TRUE)
	{
		WaitForSingleObject(hMutex, INFINITE);//如果全局互斥对象是有信号状态,则获得该对象,
		//直到调用ReleaseMutex之前,互斥对象是无信号状态,其它线程不能对互斥对象进行访问
		if(tickets > 0)	
		{
			Sleep(1);
			printf("Thread1 sell tickets : %d\n", tickets-- );
		}
		else
			break;
		ReleaseMutex(hMutex);//将互斥对象设置为有信号状态
		
	}
	return 0;
	
}
DWORD WINAPI Fun2Proc(LPVOID lpParameter)				  
{      
	while(TRUE)
	{
		WaitForSingleObject(hMutex, INFINITE);
		if (tickets > 0)
		{	
			Sleep(1);
			printf("Thread2 sell tickets : %d\n", tickets-- );
		}
		else
			break;
		ReleaseMutex(hMutex);
		}
	return 0;
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值