术语 | createmutex |
释义 | CreateMutex 语法: C++ HANDLE WINAPI CreateMutex( __in_opt LPSECURITY_ATTRIBUTES lpMutexAttributes, __in BOOL bInitialOwner, __in_opt LPCTSTR lpName ); CreateMutex函数 创建或打开一个有名或无名的互斥对象。 要指定一个对象的访问掩码,使用CreateMutexEx功能。 参数 lpMutexAttributes [中,可选] 一个SECURITY_ATTRIBUTES结构的指针。如果该参数为NULL,处理不能由子进程继承。 结构的lpSecurityDescriptor成员指定一个新的mutex安全描述符。如果lpMutexAttributes为NULL,则互斥得到默认的安全描述。在对来自互斥默认安全描述符的ACL或模拟的主要创造者的象征。有关更多信息,请参阅同步对象的安全和访问权限。 bInitialOwner [in] 如果该值为TRUE,调用创建互斥体,调用线程获得互斥体对象的初始所有权。否则,调用线程不会获得互斥体的所有权。要确定如果调用方创建互斥,看到的返回值部分。 lpName [中,可选] 该互斥对象的名称。该名称被限制为MAX_PATH字符。名称比较是区分大小写的。 如果lpName匹配现有互斥对象的名字命名,该功能要求MUTEX_ALL_ACCESS访问权限。在这种情况下,bInitialOwner参数将被忽略,因为它已被创建进程设置。如果lpMutexAttributes参数不是NULL,它确定是否可以被继承处理,但它的安全描述符的成员被忽略。 如果lpName为NULL,则互斥对象创建没有名称。 如果lpName匹配现有的事件,信号量,可等待定时器,工作,或文件映射对象,该函数失败,而且GetLastError函数返回出现ERROR_INVALID_HANDLE名。这是因为这些对象共享相同的名称空间。 这个名称可以有一个“全球\\”或“Local \\”前缀明确创建对象的全球或会话名称空间。名称的其余部分可以包含以外的任何字符反斜杠字符(\\)。如需信息见命名内核对象。快速用户切换是使用终端服务会话。内核对象名称必须遵循概述了终端服务,使应用程序能够支持多个用户的指导方针。 窗口2000:如果终端服务没有运行,“全球\\”和“地方\\”前缀将被忽略。名称的其余部分可以包含反斜杠以外的任何字符的字符。 该对象可以创建一个私人空间。有关更多信息,请参见对象命名。 返回值 如果函数成功,返回值是一个句柄到新创建的互斥对象。 如果函数失败,返回值为NULL。为了获得更多错误信息,调用GetLastError。 如果锁是一个名为互斥和对象调用此函数之前存在,返回值是一个句柄现有的对象,GetLastError返回ERROR_ALREADY_EXISTS,bInitialOwner被忽略,调用线程不获批准的所有权。但是,如果调用了有限的访问权限,该函数将失败,ERROR_ACCESS_DENIED和调用应该使用OpenMutex函数。 备注 在处理CreateMutex返回有MUTEX_ALL_ACCESS访问权限,它可以在任何函数,需要一个句柄互斥对象,提供来电者已被授予使用。如果从一个互斥服务或线程模拟不同的用户创建的,您可以申请一个安全描述符当您创建互斥量,或通过改变其默认的DACL为创建进程的默认安全描述符。有关更多信息,请参阅同步对象的安全和访问权限。 如果您使用命名互斥限制您的应用程序单实例,恶意用户可以创建此互斥量在此之前,防止启动您的应用程序。为了防止这种情况下,创建一个随机命名的互斥和存储名称,以便它只能由授权用户获得的。此外,还可以用于此目的的文件。为了限制您的应用程序每个用户实例,创建一个用户配置文件目录锁定的文件。 任何调用进程的线程可以指定互斥对象在调用句柄在等待职能之一。单对象等待函数返回时,指定对象的状态信号。在多对象等待函数可以奉命返回或者当任何一个或指定对象的所有信号。当一个等待函数返回时,等待线程被释放继续执行。 一个互斥对象的状态时,信号没有任何线程拥有。 The creating thread can use the bInitialOwner flag to request immediate ownership of the mutex.否则,一个线程必须使用等待函数请求权之一。当互斥的状态信号,一个等待线程被授予权,是互斥的状态更改为无信号,并等待函数返回。只有一个线程可以拥有在任何时间互斥。所属线程使用ReleaseMutex函数来释放它的所有权。 线程拥有互斥可以指定重复等待功能相同的互斥体通话过程中不会阻止其执行。 Typically, you would not wait repeatedly for the same mutex, but this mechanism prevents a thread from deadlocking itself while waiting for a mutex that it already owns.然而,释放其所有权,该线程必须要求每次ReleaseMutex一次满意的互斥等待。 两个或多个进程可以调用CreateMutex创建相同的命名互斥。第一个进程实际创建互斥量,并有足够的访问权限只需打开一个句柄现有互斥事后处理。这使得多个进程得到相同的互斥处理,同时,减轻责任确保用户创建进程启动第一。当使用此技术,您应该设置bInitialOwner标志为FALSE,否则,它可以难以确定哪个进程已初步所有权。 多个进程可以有相同的互斥对象句柄,使使用的进程间同步对象。下列对象共享机制可用: 子进程的CreateProcess函数创建可以继承的句柄互斥对象如果CreateMutex lpMutexAttributes参数启用继承。这种机制为有名和无名互斥。 一个进程可以指定处理的互斥对象在调用DuplicateHandle函数来创建一个重复的句柄可以被另一个进程使用。这种机制为有名和无名互斥。 一个进程可以调用指定命名互斥的OpenMutex或CreateMutex函数检索的句柄互斥对象。 使用CloseHandle函数关闭处理。该系统关闭时自动处理过程终止。互斥量对象被销毁时,其最后处理已关闭。 实例 举一个例子,它使用CreateMutex,请参阅使用互斥对象。 要求: 最低支持:client-Windows 2000专业版 最低支持server-Windows 2000服务器 HeaderWinbase.h(头文件:winuser.h) LibraryKernel32.lib DLLKernel32.dll Unicode和ANSI namesCreateMutexW(Unicode)和CreateMutexA(ANSI)的 参见 CloseHandle CreateMutexEx CreateProcess的 DuplicateHandle 互斥对象 对象名称 OpenMutex ReleaseMutex SECURITY_ATTRIBUTES 同步功能 如果有任何问题和意见,请发送给微软(wsddocfb@microsoft.com) 生成日期:2009年8月27日 ==英文原文==CreateMutex Function Creates or opens a named or unnamed mutex object. To specify an access mask for the object, use the CreateMutexEx function. Syntax C++ HANDLE WINAPI CreateMutex( __in_opt LPSECURITY_ATTRIBUTES lpMutexAttributes, __in BOOL bInitialOwner, __in_opt LPCTSTR lpName ); Parameters lpMutexAttributes [in, optional] A pointer to a SECURITY_ATTRIBUTES structure. If this parameter is NULL, the handle cannot be inherited by child processes. The lpSecurityDescriptor member of the structure specifies a security descriptor for the new mutex. If lpMutexAttributes is NULL, the mutex gets a default security descriptor. The ACLs in the default security descriptor for a mutex come from the primary or impersonation token of the creator. For more information, see Synchronization Object Security and Access Rights . bInitialOwner [in] If this value is TRUE and the caller created the mutex, the calling thread obtains initial ownership of the mutex object. Otherwise, the calling thread does not obtain ownership of the mutex. To determine if the caller created the mutex, see the Return Values section. lpName [in, optional] The name of the mutex object. The name is limited to MAX_PATH characters. Name comparison is case sensitive. If lpName matches the name of an existing named mutex object, this function requests the MUTEX_ALL_ACCESS access right. In this case, the bInitialOwner parameter is ignored because it has already been set by the creating process. If the lpMutexAttributes parameter is not NULL, it determines whether the handle can be inherited, but its security-descriptor member is ignored. If lpName is NULL, the mutex object is created without a name. If lpName matches the name of an existing event, semaphore, waitable timer, job, or file-mapping object, the function fails and the GetLastError function returns ERROR_INVALID_HANDLE. This occurs because these objects share the same name space. The name can have a "Global\\" or "Local\\" prefix to explicitly create the object in the global or session name space. The remainder of the name can contain any character except the backslash character (\\). For more information, see Kernel Object Namespaces . Fast user switching is implemented using Terminal Services sessions. Kernel object names must follow the guidelines outlined for Terminal Services so that applications can support multiple users. Windows 2000: If Terminal Services is not running, the "Global\\" and "Local\\" prefixes are ignored. The remainder of the name can contain any character except the backslash character. The object can be created in a private namespace. For more information, see Object Namespaces . Return Value If the function succeeds, the return value is a handle to the newly created mutex object. If the function fails, the return value is NULL. To get extended error information, call GetLastError. If the mutex is a named mutex and the object existed before this function call, the return value is a handle to the existing object, GetLastError returns ERROR_ALREADY_EXISTS, bInitialOwner is ignored, and the calling thread is not granted ownership. However, if the caller has limited access rights, the function will fail with ERROR_ACCESS_DENIED and the caller should use the OpenMutex function. Remarks The handle returned by CreateMutex has the MUTEX_ALL_ACCESS access right; it can be used in any function that requires a handle to a mutex object, provided that the caller has been granted access. If a mutex is created from a service or a thread that is impersonating a different user, you can either apply a security descriptor to the mutex when you create it, or change the default security descriptor for the creating process by changing its default DACL. For more information, see Synchronization Object Security and Access Rights . If you are using a named mutex to limit your application to a single instance, a malicious user can create this mutex before you do and prevent your application from starting. To prevent this situation, create a randomly named mutex and store the name so that it can only be obtained by an authorized user. Alternatively, you can use a file for this purpose. To limit your application to one instance per user, create a locked file in the user's profile directory. Any thread of the calling process can specify the mutex-object handle in a call to one of the wait functions . The single-object wait functions return when the state of the specified object is signaled. The multiple-object wait functions can be instructed to return either when any one or when all of the specified objects are signaled. When a wait function returns, the waiting thread is released to continue its execution. The state of a mutex object is signaled when it is not owned by any thread. The creating thread can use the bInitialOwner flag to request immediate ownership of the mutex. Otherwise, a thread must use one of the wait functions to request ownership. When the mutex's state is signaled, one waiting thread is granted ownership, the mutex's state changes to nonsignaled, and the wait function returns. Only one thread can own a mutex at any given time. The owning thread uses the ReleaseMutex function to release its ownership. The thread that owns a mutex can specify the same mutex in repeated wait function calls without blocking its execution. Typically, you would not wait repeatedly for the same mutex, but this mechanism prevents a thread from deadlocking itself while waiting for a mutex that it already owns. However, to release its ownership, the thread must call ReleaseMutex once for each time that the mutex satisfied a wait. Two or more processes can call CreateMutex to create the same named mutex. The first process actually creates the mutex, and subsequent processes with sufficient access rights simply open a handle to the existing mutex. This enables multiple processes to get handles of the same mutex, while relieving the user of the responsibility of ensuring that the creating process is started first. When using this technique, you should set the bInitialOwner flag to FALSE; otherwise, it can be difficult to be certain which process has initial ownership. Multiple processes can have handles of the same mutex object, enabling use of the object for interprocess synchronization. The following object-sharing mechanisms are available: A child process created by the CreateProcess function can inherit a handle to a mutex object if the lpMutexAttributes parameter of CreateMutex enabled inheritance. This mechanism works for both named and unnamed mutexes. A process can specify the handle to a mutex object in a call to the DuplicateHandle function to create a duplicate handle that can be used by another process. This mechanism works for both named and unnamed mutexes. A process can specify a named mutex in a call to the OpenMutex or CreateMutex function to retrieve a handle to the mutex object. Use the CloseHandle function to close the handle. The system closes the handle automatically when the process terminates. The mutex object is destroyed when its last handle has been closed. Examples For an example that uses CreateMutex, see Using Mutex Objects . Requirements Minimum supported clientWindows 2000 Professional Minimum supported serverWindows 2000 Server HeaderWinbase.h (include Windows.h) LibraryKernel32.lib DLLKernel32.dll Unicode and ANSI namesCreateMutexW (Unicode) and CreateMutexA (ANSI) See Also CloseHandle CreateMutexEx CreateProcess DuplicateHandle Mutex Objects Object Names OpenMutex ReleaseMutex SECURITY_ATTRIBUTES Synchronization Functions Send comments about this topic to Microsoft Build date: 8/27/2009 ==原始网址==http://msdn.microsoft.com/en-us/library/ms682411(VS.85).aspx\n |
随便看 |
|
windows api函数参考手册包含2258条windows api函数文档,详细介绍nodejs、java、rust调用windows api的方法技巧,是学习windows api编程的入门中文文档。