Compartir a través de


_execve, _wexecve

Carga y ejecuta nuevos procesos secundarios.

Importante

Esta API no se puede usar en aplicaciones que se ejecutan en Windows en tiempo de ejecución. Para obtener más información, vea Funciones de CRT no admitidas en aplicaciones de la Plataforma universal de Windows.

Sintaxis

intptr_t _execve(
   const char *cmdname,
   const char *const *argv,
   const char *const *envp
);
intptr_t _wexecve(
   const wchar_t *cmdname,
   const wchar_t *const *argv,
   const wchar_t *const *envp
);

Parámetros

cmdname
Ruta de acceso del archivo que se va a ejecutar.

argv
Matriz de punteros a parámetros.

envp
Matriz de punteros a la configuración del entorno.

Valor devuelto

Si se ejecuta correctamente, estas funciones no vuelven al proceso de llamada. Un valor devuelto de -1 indica un error, en cuyo caso se establece la errno variable global.

Valor de errno Descripción
E2BIG El espacio necesario para los argumentos y la configuración de entorno supera los 32 kB.
EACCES El archivo especificado tiene un bloqueo o una infracción de uso compartido.
EINVAL El parámetro no es válido.
EMFILE Hay demasiados archivos abiertos (el archivo especificado debe abrirse para determinar si es ejecutable).
ENOENT No se encuentra el archivo o la ruta de acceso.
ENOEXEC El archivo especificado no es ejecutable o tiene un formato de archivo ejecutable no válido.
ENOMEM No hay suficiente memoria disponible para ejecutar el nuevo proceso; la memoria disponible está dañada; o existe un bloque no válido, lo que indica que el proceso de llamada no se asignó correctamente.

Para obtener más información sobre estos y otros códigos de retorno, vea errno, _doserrno, _sys_errlist y _sys_nerr.

Comentarios

Cada una de estas funciones carga y ejecuta un proceso nuevo, pasando una matriz de punteros a los argumentos de la línea de comandos y una matriz de punteros a la configuración del entorno.

_execve y _wexecve validan sus parámetros. Estas funciones invocan al controlador de parámetros no válidos, como se describe en Validación de parámetros, cuando:

  • cmdname es un puntero nulo,
  • argv es un puntero nulo o puntero a una matriz vacía,
  • la matriz contiene una cadena vacía como primer argumento.

Si el controlador permite continuar la ejecución, estas funciones se establecen errno EINVALen y devuelven -1. No se inicia ningún proceso.

De manera predeterminada, el estado global de esta función está limitado a la aplicación. Para cambiar este comportamiento, consulte Estado global en CRT.

Requisitos

Función Encabezado necesario Encabezado opcional
_execve <process.h> <errno.h>
_wexecve <process.h> o <wchar.h> <errno.h>

Para obtener más información sobre compatibilidad, consulte Compatibilidad.

Ejemplo

Vea el ejemplo de , _exec_wexec functions.

Consulte también

Control de procesos y entornos
Funciones _exec, _wexec
abort
atexit
exit, , _Exit, _exit
_onexit, _onexit_m
Funciones _spawn, _wspawn
system, _wsystem