Función CreateMutexExA (synchapi.h)

Crea o abre un objeto de exclusión mutua con nombre o sin nombre y devuelve un identificador al objeto .

Sintaxis

HANDLE CreateMutexExA(
  [in, optional] LPSECURITY_ATTRIBUTES lpMutexAttributes,
  [in, optional] LPCSTR                lpName,
  [in]           DWORD                 dwFlags,
  [in]           DWORD                 dwDesiredAccess
);

Parámetros

[in, optional] lpMutexAttributes

Puntero a una estructura de SECURITY_ATTRIBUTES . Si este parámetro es NULL, los procesos secundarios no pueden heredar el identificador de exclusión mutua.

El miembro lpSecurityDescriptor de la estructura especifica un descriptor de seguridad para la nueva exclusión mutua. Si lpMutexAttributes es NULL, la exclusión mutua obtiene un descriptor de seguridad predeterminado. Las ACL del descriptor de seguridad predeterminado para una exclusión mutua proceden del token principal o de suplantación del creador. Para obtener más información, vea Synchronization Object Security and Access Rights.

[in, optional] lpName

Nombre del objeto de exclusión mutua. El nombre está limitado a MAX_PATH caracteres. La comparación de nombres distingue mayúsculas de minúsculas.

Si lpName es NULL, el objeto de exclusión mutua se crea sin un nombre.

Si lpName coincide con el nombre de un evento existente, semáforo, temporizador de espera, trabajo o objeto de asignación de archivos, se produce un error en la función y la función GetLastError devuelve ERROR_INVALID_HANDLE. Esto ocurre porque estos objetos comparten el mismo espacio de nombres.

El nombre puede tener un prefijo "Global" o "Local" para crear explícitamente el objeto en el espacio de nombres global o de sesión. El resto del nombre puede contener cualquier carácter excepto el carácter de barra diagonal inversa (\). Para obtener más información, vea Espacios de nombres de objeto kernel. El cambio rápido de usuarios se implementa mediante sesiones de Terminal Services. Los nombres de objeto de kernel deben seguir las directrices descritas para Terminal Services para que las aplicaciones puedan admitir varios usuarios.

El objeto se puede crear en un espacio de nombres privado. Para obtener más información, vea Espacios de nombres de objeto.

[in] dwFlags

Este parámetro puede ser 0 o el valor siguiente.

Valor Significado
CREATE_MUTEX_INITIAL_OWNER
0x00000001
El creador del objeto es el propietario inicial de la exclusión mutua.

[in] dwDesiredAccess

Máscara de acceso para el objeto de exclusión mutua. Para obtener una lista de los derechos de acceso, vea Synchronization Object Security and Access Rights.

Valor devuelto

Si la función se ejecuta correctamente, el valor devuelto es un identificador para el objeto de exclusión mutua recién creado.

Si la función no se realiza correctamente, el valor devuelto es NULL. Para obtener información de error extendida, llame a GetLastError.

Si la exclusión mutua es una exclusión mutua con nombre y el objeto existía antes de esta llamada de función, el valor devuelto es un identificador para el objeto existente y la función GetLastError devuelve ERROR_ALREADY_EXISTS.

Comentarios

Si usa una exclusión mutua con nombre para limitar la aplicación a una sola instancia, un usuario malintencionado puede crear esta exclusión mutua antes de hacerlo e impedir que se inicie la aplicación. Para evitar esta situación, cree una exclusión mutua con nombre aleatorio y almacene el nombre para que un usuario autorizado solo pueda obtenerlo. Como alternativa, puede usar un archivo para este fin. Para limitar la aplicación a una instancia por usuario, cree un archivo bloqueado en el directorio de perfiles del usuario.

Cualquier subproceso del proceso de llamada puede especificar el identificador de objeto de exclusión mutua en una llamada a una de las funciones de espera. Las funciones de espera de objeto único devuelven cuando se señala el estado del objeto especificado. Se pueden indicar a las funciones de espera de varios objetos que devuelvan cuando se señalizan todos los objetos especificados. Cuando se devuelve una función wait, se libera el subproceso en espera para continuar su ejecución.

El estado de un objeto de exclusión mutua se señala cuando no pertenece a ningún subproceso. El subproceso de creación puede usar el parámetro dwFlags para solicitar la propiedad inmediata de la exclusión mutua. De lo contrario, un subproceso debe usar una de las funciones de espera para solicitar la propiedad. Cuando se señala el estado de la exclusión mutua, se concede propiedad a un subproceso en espera, el estado de la exclusión mutua cambia a no asignado y la función wait devuelve. Solo un subproceso puede poseer una exclusión mutua en un momento dado. El subproceso propietario usa la función ReleaseMutex para liberar su propiedad.

El subproceso que posee una exclusión mutua puede especificar la misma exclusión mutua en llamadas de función de espera repetidas sin bloquear su ejecución. Normalmente, no esperaría repetidamente la misma exclusión mutua, pero este mecanismo impide que un subproceso se interbloquee a sí mismo mientras espera una exclusión mutua que ya posee. Sin embargo, para liberar su propiedad, el subproceso debe llamar a ReleaseMutex una vez por cada vez que la exclusión mutua satisface una espera.

Dos o más procesos pueden llamar a CreateMutex para crear la misma exclusión mutua con nombre. El primer proceso crea realmente la exclusión mutua y los procesos posteriores con derechos de acceso suficientes simplemente abren un identificador a la exclusión mutua existente. Esto permite que varios procesos obtengan identificadores de la misma exclusión mutua, a la vez que alivian al usuario la responsabilidad de asegurarse de que el proceso de creación se inicia primero. Al usar esta técnica, no debe usar la marca CREATE_MUTEX_INITIAL_OWNER ; de lo contrario, puede ser difícil estar seguro de qué proceso tiene propiedad inicial.

Varios procesos pueden tener identificadores del mismo objeto de exclusión mutua, lo que permite el uso del objeto para la sincronización entre procesos. Están disponibles los siguientes mecanismos de uso compartido de objetos:

  • Un proceso secundario creado por la función CreateProcess puede heredar un identificador a un objeto de exclusión mutua si el parámetro lpMutexAttributes de la herencia habilitada para CreateMutex . Este mecanismo funciona para exclusiones mutuas con nombre y sin nombre.
  • Un proceso puede especificar el identificador para un objeto de exclusión mutua en una llamada a la función DuplicateHandle para crear un identificador duplicado que otro proceso pueda usar. Este mecanismo funciona para exclusiones mutuas con nombre y sin nombre.
  • Un proceso puede especificar una exclusión mutua con nombre en una llamada a la función [OpenMutex](./nf-synchapi-openmutexw.md) o CreateMutex para recuperar un identificador al objeto de exclusión mutua.
Use la función CloseHandle para cerrar el identificador. El sistema cierra el identificador automáticamente cuando finaliza el proceso. El objeto de exclusión mutua se destruye cuando se ha cerrado su último identificador.

Nota

El encabezado synchapi.h define CreateMutexEx como alias que selecciona automáticamente la versión ANSI o Unicode de esta función en función de la definición de la constante de preprocesador UNICODE. La combinación del uso del alias neutral de codificación con código que no es neutral de codificación puede dar lugar a errores de coincidencia que dan lugar a errores de compilación o tiempo de ejecución. Para obtener más información, vea Convenciones para prototipos de función.

Requisitos

Requisito Value
Cliente mínimo compatible Windows Vista [aplicaciones de escritorio | aplicaciones para UWP]
Servidor mínimo compatible Windows Server 2008 [aplicaciones de escritorio | aplicaciones para UWP]
Plataforma de destino Windows
Encabezado synchapi.h (incluye Windows.h en Windows 7, Windows Server 2008 Windows Server 2008 R2)
Library Kernel32.lib
Archivo DLL Kernel32.dll

Vea también

CloseHandle

Objetos de exclusión mutua

Funciones de sincronización