Compartir a través de


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 CreateWindow para crear una ventana superpuesta si el parámetro de nWidth de CreateWindow es CW_USEDEFAULT.

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
STARTF_FORCEONFEEDBACK
0x00000040
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.

STARTF_FORCEOFFFEEDBACK
0x00000080
Indica que el cursor de comentarios se ha forzado mientras se inicia el proceso. Se muestra el cursor Selección normal.
STARTF_PREVENTPINNING
0x00002000
Indica que las ventanas creadas por el proceso no se pueden anclar en la barra de tareas.

Esta marca debe combinarse con STARTF_TITLEISAPPID.

STARTF_RUNFULLSCREEN
0x00000020
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.

STARTF_TITLEISAPPID
0x00001000
El miembro lpTitle de contiene un appUserModelID. Este identificador controla cómo la barra de tareas y menú Inicio presenta la aplicación y permite asociarla con los accesos directos y listas de accesos directos correctos. Por lo general, las aplicaciones usarán el SetCurrentProcessExplicitAppUserModelID y GetCurrentProcessExplicitAppUserModelID funciones en lugar de establecer esta marca. Para obtener más información, consulte identificadores de modelo de usuario de aplicación.

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.

STARTF_TITLEISLINKNAME
0x00000800
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.

STARTF_UNTRUSTEDSOURCE
0x00008000
La línea de comandos procede de un origen que no es de confianza. Para obtener más información, vea Comentarios.
STARTF_USECOUNTCHARS
0x00000008
Los dwXCountChars y dwYCountChars contienen información adicional.
STARTF_USEFILLATTRIBUTE
0x00000010
El miembro dwFillAttribute contiene información adicional.
STARTF_USEHOTKEY
0x00000200
El miembro hStdInput contiene información adicional.

Esta marca no se puede usar con STARTF_USESTDHANDLES.

STARTF_USEPOSITION
0x00000004
Los miembros de dwX y dwY contienen información adicional.
STARTF_USESHOWWINDOW
0x00000001
El miembro wShowWindow contiene información adicional.
STARTF_USESIZE
0x00000002
Los dwXSize y dwYSize miembros contienen información adicional.
STARTF_USESTDHANDLES
0x00000100
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 GetStartupInfo para recuperar la estructura de startupINFO de especificada al crear el proceso.

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 getStartupInfo para recuperar la estructura de STARTUPINFO de y comprobar que se establece hStdOutput. Si es así, use GetMonitorInfo para comprobar si hStdOutput es un identificador de monitor válido (HMONITOR). Después, el proceso puede usar el identificador para colocar sus ventanas.

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)

Consulte también

CreateProcess

CreateProcessAsUser

CreateProcessWithLogonW

CreateProcessWithTokenW

GetStartupInfo