CreateMutex 【转】

C++
API CreateMutex

找出当前系统是否已经存在指定进程的实例。如果没有则创建一个互斥体。CreateMutex()函数可用来创建一个有名或无名的互斥量对象。

HANDLE CreateMutex(   
LPSECURITY_ATTRIBUTES lpMutexAttributes, // 指向安全属性的指针   
BOOL bInitialOwner, // 初始化互斥对象的所有者   
LPCTSTR lpName // 指向互斥对象名的指针   );

返回值   
Long,如执行成功,就返回互斥体对象的句柄;零表示出错。会设置GetLastError。
即使返回的是一个有效句柄,但倘若指定的名字已经存在,GetLastError也会设为ERROR_ALREADY_EXISTS

参数表   参数 类型及说明   
lpMutexAttributes SECURITY_ATTRIBUTES,指定一个SECURITY_ATTRIBUTES结构,或传递零值(将参数声明为ByVal As Long,并传递零值),
表示使用不允许继承的默认描述符。

bInitialOwner BOOL,如创建进程希望立即拥有互斥体,则设为TRUE。一个互斥体同时只能由一个线程拥有。是FALSE,表示刚刚创建的这个Mutex不属于任何线程
也就是没有任何线程拥有他,一个Mutex在没有任何线程拥有他的时候,他是处于激发态的, 所以处于有信号状态。

lpName String,指定互斥体对象的名字。用vbNullString创建一个未命名的互斥体对象。如已经存在拥有这个名字的一个事件,
则打开现有的已命名互斥体。这个名字可能不与现有的事件、信号机、可等待计时器或文件映射相符
该名称可以有一个"Global\" 或"Local\" 前缀,明确地建立在全局或会话命名空间的对象。剩余的名称可以包含任何字符,除反斜杠字符(\)。
使用终端服务(Terminal Services)会话,实现用户切换。内核对象名称必须遵循的指导方针,使应用程序可以支持多个用户终端服务。
typedef BOOL (CALLBACK* VERIFY_VERSION_INFO)
 (
 LPOSVERSIONINFOEX lpVersionInformation, 
 DWORD dwTypeMask, 
 DWORDLONG dwlConditionMask
 );

typedef ULONGLONG (CALLBACK* VER_SETCONDITION_MASK)(
 ULONGLONG dwlConditionMask,
 DWORD dwTypeBitMask,
 BYTE dwConditionMask
 );
bool IsValidTerminalService()
{
 bool result = FALSE;
 HINSTANCE hInst = LoadLibrary("Kernel32.Dll");
 if (hInst != NULL)
 {
  VERIFY_VERSION_INFO procVerifyVersionInfo = reinterpret_cast<VERIFY_VERSION_INFO>(::GetProcAddress(hInst, "VerifyVersionInfoA"));
  VER_SETCONDITION_MASK procVerSetConditionMask = reinterpret_cast<VER_SETCONDITION_MASK>(::GetProcAddress(hInst, "VerSetConditionMask"));

if (procVerifyVersionInfo != NULL && procVerSetConditionMask != NULL)
  {
   OSVERSIONINFOEX osVersionInfo;
   DWORDLONG dwlConditionMask = 0;

//(&osVersionInfo, sizeof(OSVERSIONINFOEX));
   osVersionInfo.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX);
   osVersionInfo.wSuiteMask = VER_SUITE_TERMINAL; // Terminal Services

dwlConditionMask = procVerSetConditionMask(dwlConditionMask, VER_SUITENAME, VER_AND);
   result = procVerifyVersionInfo(&osVersionInfo,VER_SUITENAME,dwlConditionMask);

}
  ::FreeLibrary(hInst);
 }

return result;
}

注意:
一旦不再需要,注意必须用CloseHandle函数将互斥体句柄关闭。从属于它的所有句柄都被关闭后,
就会删除对象   进程中止前,一定要释放互斥体,如不慎未采取这个措施,就会将这个互斥体标记为废弃,并自动释放所有权。
共享这个互斥体的其他应用程序也许仍然能够用它,但会接收到一个废弃状态信息,指出上一个所有进程未能正常关闭。这种状况是否会造成影响取决于涉及到的具体应用程序

使用例子:
(1)、 h_mutex1=CreateMutex(NULL,FALSE,"mutex_for_readcount");//创建一个互斥体   
(2)、HANDLE m_hMutex = CreateMutex(NULL, FALSE, "Sample07");// 检查错误代码   
if (GetLastError() == ERROR_ALREADY_EXISTS)   
{   
// 如果已有互斥量存在则释放句柄并复位互斥量   
CloseHandle(m_hMutex);   
m_hMutex = NULL;   // 程序退出   
return FALSE;   
};   //上面这段代码演示了有名互斥量在进程互斥中的用法。代码的核心是CreateMutex()对有名互斥量的创建。   
CreateMutex() 用于有独占要求的程序 (在其进程运行期间不允许其他使用此端口设备的程序运行,或不允许同名程序运行)。

CreateMutex 【转】,布布扣,bubuko.com

时间: 2024-10-23 15:01:26

CreateMutex 【转】的相关文章

WinApi多线程(CreateThread,CreateMutex,ReleaseMutex)

注:本文写得十分简略.如感到难以理解,请立即参考另一篇写得比我好得多的文章 我们先看一个示例 1 #include <windows.h> 2 #include <stdio.h> 3 4 DWORD WINAPI reportFunc(LPVOID); // 线程函数的一般原型.可以不返回任何值 5 6 #define CntMsg 100 7 8 int main() 9 { 10 /* 建立一个新线程并令其立即执行,返回这个线程的handle 11 * 第三个参数report

Qt保证只有一个实例(将CreateMutex得到的handle通过转换得到值)

使用CreateMutex 可以实现只启动一个应用程序实例 view plaincopy to clipboardprint?#include <QApplication>#include <QtNetwork>#include "mydlg.h" #ifdef Q_WS_WIN#include <windows.h>#endif int main(int argc, char * argv[]) {QApplication app(argc,arg

【温故Delphi】Win32API之CreateMutex

解决问题 如何让一个软件在一台机器上只能运行一个实例呢?这个问题用专业术语就是进程互斥.这个问题可以通过CreateMutex来解决. 进程互斥的核心思想:进程在启动时首先检查是否存在此进程实例,如果没有则创建进程并设置进程实例已存在的标记. CreateMutex用于创建一个互斥体: OpenMutex为现有的一个已命名互斥体对象创建一个新句柄: ReleaseMutex释放由线程拥有的一个互斥体的控制权. 具体实现代码如下: 1 constructor TUniqueAppInstance.

CreateMutex实现只能打开一个客户端

#include "stdafx.h" #include <Windows.h> #include <iostream> using namespace std; int _tmain (int argc, LPTSTR argv[]) { HANDLE h=CreateMutex(NULL,TRUE,"AAAAAAA"); if(GetLastError()==ERROR_ALREADY_EXISTS){ CloseHandle(h); r

CreateMutex和WaitForSingleObject组合的有关问题

CreateMutex和WaitForSingleObject组合的问题在网上看见一个dll的代码,其中有这样几行 case   DLL_PROCESS_ATTACH:   ........ hmutex=CreateMutex(NULL,FALSE,NULL);//1 WaitForSingleObject(hmutex,INFINITE);//2 ...... ReleaseMutex//3 按照我的理解,程序应该停在2处,因为其他地方没有ReleaseMutex,所以对代码的意义感到很奇怪

Delphi CreateMutex 防止程序多次运行

windows是个多用户多任务的操作系统,支持多个程序同时运行,如果你的程序不想让用户同时运行一个以上, 那应该怎样做呢? 本文将介绍避免用户同时运行多个程序的例子. 需要用到的函数CreateMutex ,CreateMutex 函数是windows中一个并不常用的函数, 该函数对象在系统中只能存在一个实例且是互斥体,所以利用这种特性就很简单的实现了我们的要求. [函数原声明]: function CreateMutex(lpMutexAttributes: PSecurityAttribut

CreateMutex()参数问题

举例: hMutex = CreateMutex(NULL, FALSE,"screen"); 报错 error C2664:"CreateMutexW": 不能将参数 3 从"const char [7]"转换为"LPCWSTR" 与指向的类型无关:转换要求 reinterpret_cast.C 样式转换或函数样式转换: 解决:Ascii 环境调用CreateMutexA,unciode环境调用CreateMutexW 此例

CreateMutex 创建一个有名字的互斥量的时候hMutex=CreateMutex(NULL,TRUE,&quot;tickets&quot;)报错

编译器报错: 不能将参数 3 从“const char [8]”转换为“LPCWSTR”,怎么改成LPCWSTR类型 更改方法: hMutex=CreateMutex(NULL,TRUE,L"tickets") 只需要在第三个参数,即名字前面加一个大写的 L 即可 HANDLE CreateMutex( LPSECURITY_ATTRIBUTES          lpMutexAttributes, // 指向安全属性的指针 BOOL                         

CreateMutex() 、ReleaseMutex()

功能: CreateMutex() 用于有独占要求的程序 (在其进程运行期间不允许其他使用此端口设备的程序运行,或不允许同名程序运行). 比如运行金山词霸时,一次只能运行一个实例,当运行第二个实例时,实际上是激活第一个实例,将其带到最顶层. 原型: 1 HANDLE CreateMutex( 2 LPSECURITY_ATTRIBUTES lpMutexAttributes, 3 BOOL bInitialOwner, 4 LPCTSTR lpName 5 ); 参数: lpMutexAttri