一、示例代码:
// 判断是否重复运行
BOOL IsAlreadyRun()
{
HANDLE hMutex = NULL;
hMutex = ::CreateMutex(NULL, FALSE, "TEST");
if (hMutex)
{
if (ERROR_ALREADY_EXISTS == ::GetLastError())
{
return TRUE;
}
}
return FALSE;
}
int _tmain(int argc, _TCHAR* argv[])
{
// 判断是否重复运行
if (IsAlreadyRun())
{
printf("Already Run!!!!\n");
}
else
{
printf("NOT Already Run!\n");
}
system("pause");
return 0;
}
二、函数介绍:
CreateMutex(
_In_opt_ LPSECURITY_ATTRIBUTES lpMutexAttributes,
_In_ BOOL bInitialOwner,
_In_opt_ LPCSTR lpName
);
- lpMutexAttributes [in, optional] 指向 _SECURITY_ATTRIBUTES 结构的指针。如果此参数为 NULL,则该句柄不能由子进程继承。
- bInitialOwner [in] 如果此值为 TRUE 并且调用者创建了互斥锁,则调用线程将获得互斥锁对象的初始所有权。否则,调用线程不会获得互斥锁的所有权。
- lpName [in,optional] 互斥对象的名称。该名称仅限于 MAX_PATH 字符,名称区分大小写。如果 lpName 为NULL,则会创建不带名称的互斥对象。
如果 lpName 与现有事件、信号量、等待定时器、作业或文件映射对象的名称匹配,且这些对象共享相同的名称空间,则该函数将失败,并且 GetLastError 函数返回 ERROR_INVALID_HANDLE。
本文提供了一个使用C++实现的防止程序重复运行的示例代码,通过创建带有名称的互斥对象(Mutex),可以确保同一时间内只有一个实例在运行。详细介绍了CreateMutex函数的参数及其作用。
357

被折叠的 条评论
为什么被折叠?



