Estructura STARTUPINFOW (processthreadsapi.h)
Especifica la estación de ventana, el escritorio, los identificadores estándar y la apariencia de la ventana principal de un proceso en el momento de la creación.
Sintaxis
typedef struct _STARTUPINFOW {
DWORD cb;
LPWSTR lpReserved;
LPWSTR lpDesktop;
LPWSTR lpTitle;
DWORD dwX;
DWORD dwY;
DWORD dwXSize;
DWORD dwYSize;
DWORD dwXCountChars;
DWORD dwYCountChars;
DWORD dwFillAttribute;
DWORD dwFlags;
WORD wShowWindow;
WORD cbReserved2;
LPBYTE lpReserved2;
HANDLE hStdInput;
HANDLE hStdOutput;
HANDLE hStdError;
} STARTUPINFOW, *LPSTARTUPINFOW;
Miembros
cb
Tamaño de la estructura, en bytes.
lpReserved
Reservado; debe ser NULL.
lpDesktop
El nombre del escritorio o el nombre de la estación de escritorio y ventana para este proceso. Una barra diagonal inversa en la cadena indica que la cadena incluye los nombres de la estación de escritorio y de ventana.
Para obtener más información, consulte conexión de subprocesos a unde escritorio.
lpTitle
En el caso de los procesos de consola, este es el título que se muestra en la barra de título si se crea una nueva ventana de consola. Si es NULL, el nombre del archivo ejecutable se usa como título de la ventana en su lugar. Este parámetro debe ser NULL para los procesos de gui o consola que no crean una nueva ventana de consola.
dwX
Si dwFlags especifica STARTF_USEPOSITION, este miembro es el desplazamiento x de la esquina superior izquierda de una ventana si se crea una nueva ventana, en píxeles. De lo contrario, se omite este miembro.
El desplazamiento se encuentra en la esquina superior izquierda de la pantalla. En el caso de los procesos de GUI, la posición especificada se usa la primera vez que el nuevo proceso llama a CreateWindow para crear una ventana superpuesta si el parámetro x de createWindow es CW_USEDEFAULT.
dwY
Si dwFlags especifica STARTF_USEPOSITION, este miembro es el desplazamiento y de la esquina superior izquierda de una ventana si se crea una nueva ventana, en píxeles. De lo contrario, se omite este miembro.
El desplazamiento se encuentra en la esquina superior izquierda de la pantalla. Para los procesos de GUI, la posición especificada se usa la primera vez que el nuevo proceso llama a CreateWindow para crear una ventana superpuesta si el parámetro y de createWindow es CW_USEDEFAULT.
dwXSize
Si dwFlags especifica STARTF_USESIZE, este miembro es el ancho de la ventana si se crea una nueva ventana, en píxeles. De lo contrario, se omite este miembro.
En el caso de los procesos de GUI, solo se usa la primera vez que el nuevo proceso llama a
dwYSize
Si dwFlags especifica STARTF_USESIZE, este miembro es el alto de la ventana si se crea una nueva ventana, en píxeles. De lo contrario, se omite este miembro.
En el caso de los procesos de GUI, se usa solo la primera vez que el nuevo proceso llama a CreateWindow para crear una ventana superpuesta si el parámetro nHeight de createWindow es CW_USEDEFAULT.
dwXCountChars
Si dwFlags especifica STARTF_USECOUNTCHARS, si se crea una nueva ventana de consola en un proceso de consola, este miembro especifica el ancho del búfer de pantalla, en columnas de caracteres. De lo contrario, se omite este miembro.
dwYCountChars
Si dwFlags especifica STARTF_USECOUNTCHARS, si se crea una nueva ventana de consola en un proceso de consola, este miembro especifica el alto del búfer de pantalla, en filas de caracteres. De lo contrario, se omite este miembro.
dwFillAttribute
Si dwFlags especifica STARTF_USEFILLATTRIBUTE, este miembro es el texto inicial y los colores de fondo si se crea una nueva ventana de consola en una aplicación de consola. De lo contrario, se omite este miembro.
Este valor puede ser cualquier combinación de los siguientes valores: FOREGROUND_BLUE, FOREGROUND_GREEN, FOREGROUND_RED, FOREGROUND_INTENSITY, BACKGROUND_BLUE, BACKGROUND_GREEN, BACKGROUND_RED y BACKGROUND_INTENSITY. Por ejemplo, la siguiente combinación de valores genera texto rojo en un fondo blanco:
FOREGROUND_RED| BACKGROUND_RED| BACKGROUND_GREEN| BACKGROUND_BLUE
dwFlags
Campo de bits que determina si se usan determinados miembros STARTUPINFO cuando el proceso crea una ventana. Este miembro puede ser uno o varios de los siguientes valores.
Valor | Significado |
---|---|
|
Indica que el cursor está en modo de comentarios durante dos segundos después de se llama a CreateProcess. Se muestra el cursor Trabajar en segundo plano (vea la pestaña Punteros en la utilidad Panel de control del mouse).
Si durante esos dos segundos, el proceso realiza la primera llamada gui, el sistema proporciona cinco segundos más al proceso. Si durante esos cinco segundos, el proceso muestra una ventana, el sistema proporciona cinco segundos más al proceso para terminar de dibujar la ventana. El sistema desactiva el cursor de comentarios después de la primera llamada a GetMessage, independientemente de si el proceso está dibujando. |
|
Indica que el cursor de comentarios se ha forzado mientras se inicia el proceso. Se muestra el cursor Selección normal. |
|
Indica que las ventanas creadas por el proceso no se pueden anclar en la barra de tareas.
Esta marca debe combinarse con STARTF_TITLEISAPPID. |
|
Indica que el proceso debe ejecutarse en modo de pantalla completa, en lugar de en modo de ventana.
Esta marca solo es válida para las aplicaciones de consola que se ejecutan en un equipo x86. |
|
El miembro lpTitle de Si se usa STARTF_PREVENTPINNING, las ventanas de la aplicación no se pueden anclar en la barra de tareas. El uso de las propiedades de ventana relacionadas con AppUserModelID por la aplicación invalida esta configuración solo para esa ventana. Esta marca no se puede usar con STARTF_TITLEISLINKNAME. |
|
El miembro lpTitle contiene la ruta de acceso del archivo de acceso directo (.lnk) que el usuario invocó para iniciar este proceso. Normalmente, el shell establece esto cuando se invoca un archivo .lnk que apunta a la aplicación iniciada. La mayoría de las aplicaciones no tendrán que establecer este valor.
Esta marca no se puede usar con STARTF_TITLEISAPPID. |
|
La línea de comandos procede de un origen que no es de confianza. Para obtener más información, vea Comentarios. |
|
Los |
|
El miembro |
|
El miembro Esta marca no se puede usar con STARTF_USESTDHANDLES. |
|
Los miembros de dwX y dwY contienen información adicional. |
|
El miembro wShowWindow contiene información adicional. |
|
Los dwXSize y dwYSize miembros contienen información adicional. |
|
Los hStdInput, hStdOutputy miembros de hStdError contienen información adicional.
Si se especifica esta marca al llamar a una de las funciones de creación de procesos, los identificadores deben ser heredables y el parámetro bInheritHandles de la función debe establecerse en TRUE. Para obtener más información, vea Handle Inheritance. Si se especifica esta marca al llamar a la función getStartupInfo, estos miembros son el valor de identificador especificado durante la creación del proceso o INVALID_HANDLE_VALUE. Los identificadores deben cerrarse con CloseHandle cuando ya no sean necesarios. Esta marca no se puede usar con STARTF_USEHOTKEY. |
wShowWindow
Si dwFlags especifica STARTF_USESHOWWINDOW, este miembro puede ser cualquiera de los valores que se pueden especificar en el parámetro nCmdShow para la función ShowWindow, excepto para SW_SHOWDEFAULT. De lo contrario, se omite este miembro.
Para los procesos de GUI, se llama a la primera vez ShowWindow, su parámetro nCmdShow se omite wShowWindow especifica el valor predeterminado. En llamadas posteriores a showWindow, se usa el miembro wShowWindow si el parámetro nCmdShow de showWindow está establecido en SW_SHOWDEFAULT.
cbReserved2
Reservado para su uso por el tiempo de ejecución de C; debe ser cero.
lpReserved2
Reservado para su uso por el tiempo de ejecución de C; debe ser NULL.
hStdInput
Si dwFlags especifica STARTF_USESTDHANDLES, este miembro es el identificador de entrada estándar para el proceso. Si no se especifica STARTF_USESTDHANDLES, el valor predeterminado para la entrada estándar es el búfer de teclado.
Si dwFlags especifica STARTF_USEHOTKEY, este miembro especifica un valor de tecla de acceso rápido que se envía como parámetro wParam de un mensaje de WM_SETHOTKEY a la primera ventana de nivel superior apta creada por la aplicación propietaria del proceso. Si la ventana se crea con el estilo de ventana de WS_POPUP, no es apto a menos que también se establezca el estilo de ventana extendido WS_EX_APPWINDOW. Para obtener más información, vea CreateWindowEx.
De lo contrario, se omite este miembro.
hStdOutput
Si dwFlags especifica STARTF_USESTDHANDLES, este miembro es el identificador de salida estándar para el proceso. De lo contrario, se omite este miembro y el valor predeterminado para la salida estándar es el búfer de la ventana de consola.
Si se inicia un proceso desde la barra de tareas o la lista de accesos directos, el sistema establece hStdOutput en un identificador del monitor que contiene la barra de tareas o la lista de accesos directos que se usa para iniciar el proceso. Para obtener más información, vea Comentarios.Windows 7, Windows Server 2008 R2, Windows Vista, Windows Server 2008, Windows XP y Windows Server 2003: Este comportamiento se introdujo en Windows 8 y Windows Server 2012.
hStdError
Si dwFlags especifica STARTF_USESTDHANDLES, este miembro es el identificador de error estándar para el proceso. De lo contrario, se omite este miembro y el valor predeterminado para el error estándar es el búfer de la ventana de consola.
Observaciones
Para los procesos gráficos de interfaz de usuario (GUI), esta información afecta a la primera ventana creada por la función CreateWindow y mostrada por la función ShowWindow. En el caso de los procesos de consola, esta información afecta a la ventana de consola si se crea una nueva consola para el proceso. Un proceso puede usar la función
Si se inicia un proceso de GUI y no se especifica ninguna STARTF_FORCEONFEEDBACK o STARTF_FORCEOFFFEEDBACK, se usa el cursor de comentarios del proceso. Un proceso de GUI es uno cuyo subsistema se especifica como "ventanas".
Si se inicia un proceso desde la barra de tareas o la lista de accesos directos, el sistema establece
Si se especifica la marca STARTF_UNTRUSTEDSOURCE, la aplicación debe tener en cuenta que la línea de comandos no es de confianza. Si se establece esta marca, las aplicaciones deben deshabilitar características potencialmente peligrosas, como macros, contenido descargado e impresión automática. Esta marca es opcional. Se recomienda que las aplicaciones que llamen a CreateProcess establezcan esta marca al iniciar un programa con argumentos de línea de comandos que no son de confianza (por ejemplo, los proporcionados por el contenido web) para que el proceso recién creado pueda aplicar la directiva adecuada.
La marca de STARTF_UNTRUSTEDSOURCE se admite a partir de Windows Vista, pero no se define en los archivos de encabezado del SDK antes del SDK de Windows 10 SDK. Para usar la marca en versiones anteriores a Windows 10, puedes definirla manualmente en tu programa.
Ejemplos
En el ejemplo de código siguiente se muestra el uso de StartUpInfoW.
#include <windows.h>
#include <stdio.h>
#include <tchar.h>
void _tmain( int argc, TCHAR *argv[] )
{
STARTUPINFO si;
PROCESS_INFORMATION pi;
ZeroMemory( &si, sizeof(si) );
si.cb = sizeof(si);
ZeroMemory( &pi, sizeof(pi) );
if( argc != 2 )
{
printf("Usage: %s [cmdline]\n", argv[0]);
return;
}
// Start the child process.
if( !CreateProcess( NULL, // No module name (use command line)
argv[1], // Command line
NULL, // Process handle not inheritable
NULL, // Thread handle not inheritable
FALSE, // Set handle inheritance to FALSE
0, // No creation flags
NULL, // Use parent's environment block
NULL, // Use parent's starting directory
&si, // Pointer to STARTUPINFO structure
&pi ) // Pointer to PROCESS_INFORMATION structure
)
{
printf( "CreateProcess failed (%d).\n", GetLastError() );
return;
}
// Wait until child process exits.
WaitForSingleObject( pi.hProcess, INFINITE );
// Close process and thread handles.
CloseHandle( pi.hProcess );
CloseHandle( pi.hThread );
}
Para obtener más información sobre este ejemplo, vea Creación de procesos.
Nota
El encabezado processthreadsapi.h define STARTUPINFO 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 Conventions for Function Prototypes.
Requisitos
Requisito | Valor |
---|---|
cliente mínimo admitido | Windows XP [solo aplicaciones de escritorio] |
servidor mínimo admitido | Windows Server 2003 [solo aplicaciones de escritorio] |
encabezado de |
processthreadsapi.h (incluya Windows.h en Windows Server 2003, Windows Vista, Windows 7, Windows Server 2008 Windows Server 2008 R2) |