Windows下保证应用程序只有一个运行实例的方法C++实现

第一个程序的代码

#include <iostream>
#include <Windows.h>

using namespace std;

//线程1
DWORD WINAPI Fun1Proc(LPVOID lpParameter);

//线程2
DWORD WINAPI Fun2Proc(LPVOID lpParameter);

int tickets = 100;
HANDLE hMutex;

int main()
{
	HANDLE hThread1;
	HANDLE hThread2;

	//创建互斥对象
	//第一个参数:是一个结构体指针,NULL表示让互斥对象使用默认的安全性
	//第二个参数:指定互斥对象的初始拥有者,FALSE表示main函数不获得所有权
	//第三个参数:指定互斥对象的名称,NULL表示创建一个匿名的互斥对象
	hMutex = CreateMutex(NULL, FALSE, L"tickets");

	//创建线程
	hThread1 = CreateThread(NULL, 0, Fun1Proc, NULL, 0, NULL);
	hThread2 = CreateThread(NULL, 0, Fun2Proc, NULL, 0, NULL);
	CloseHandle(hThread1);
	CloseHandle(hThread2);
	Sleep(4000);


	return 0;

}

//线程1入口
DWORD WINAPI Fun1Proc(LPVOID lpParameter)
{
	char buf[100] = { 0 };
	while (TRUE)
	{
		//上锁,设置无信号
		//第一个参数:传递已创建的互斥对象的句柄hMutex
		//第二个参数:INFINITE表示一直等待,直到有信号才返回
		WaitForSingleObject(hMutex, INFINITE);
		if (tickets > 0)
		{
			sprintf_s(buf, "thread1 sell ticket : %d\n", tickets);
			cout << buf;
			tickets--;
		}
		else
			break;
		ReleaseMutex(hMutex);  //解锁
	}
	return 0;
}

//线程2入口
DWORD WINAPI Fun2Proc(LPVOID lpParameter)
{
	char buf[100] = { 0 };
	while (TRUE)
	{
		WaitForSingleObject(hMutex, INFINITE);
		if (tickets > 0)
		{
			sprintf_s(buf, "thread2 sell ticket : %d\n", tickets);
			cout << buf;
			tickets--;
		}
		else
			break;
		ReleaseMutex(hMutex);  //解锁
	}
	return 0;
}

第二个程序的代码,在第一个基础上多加了30到38行

在这里插入图片描述

然后先运行第一个程序,再运行第二个程序,结果如下图

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

困了就喝白茶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值