_spawnvpe, _wspawnvpe
Créer et exécuter un nouveau processus.
Important
Cette API ne peut pas être utilisée dans les applications qui s'exécutent dans les fenêtres d'exécution.Pour plus d'informations, consultez Fonctions CRT non prises en charge avec /ZW.
intptr_t _spawnvpe(
int mode,
const char *cmdname,
const char *const *argv,
const char *const *envp
);
intptr_t _wspawnvpe(
int mode,
const wchar_t *cmdname,
const wchar_t *const *argv,
const wchar_t *const *envp
);
Paramètres
mode
Mode d'exécution du processus appelantcmdname
Chemin d'accès du fichier à exécuterargv
Tableau de pointeurs vers des arguments.L'argument argv[0] est généralement un pointeur vers un chemin en mode réel ou le nom du programme en mode protégé, et argv[1] par argv[n] sont des pointeurs vers des chaînes de caractères signe plus la nouvelle liste d'arguments.L'argument argv[n +1] doit être un pointeur d' NULL pour marquer la fin de la liste d'arguments.envp
Tableau de pointeurs vers des paramètres d'environnement
Valeur de retour
La valeur de retour d' _spawnvpe synchrone ou d' _wspawnvpe (_P_WAIT spécifié pour mode) est l'état de sortie du nouveau processus.La valeur de retour d' _spawnvpe asynchrone ou d' _wspawnvpe (_P_NOWAIT ou _P_NOWAITO spécifié pour mode) est le handle de processus.L'état de sortie est 0 si le processus s'terminait normalement.Vous pouvez définir l'état de sortie à une valeur différente de zéro si le processus engendré appelle spécifiquement la routine d' exit avec un argument différent de zéro.Si le nouveau processus ne plaçait pas explicitement un rapport de sortie positif, un rapport de sortie positif indique une sortie anormale avec un arrêt ou une interruption.Une valeur de retour à 1 indique une erreur (le nouveau processus n'est pas lancé).Dans ce cas, errno a une des valeurs suivantes :
E2BIG
La liste d'arguments dépasse 1024 octetsEINVAL
l'argument d'mode est incorrectENOENT
Le fichier ou le chemin d'accès est introuvableENOEXEC
Le fichier spécifié n'est pas exécutable ou a le format de fichier exécutable non valideENOMEM
Mémoire insuffisante est disponible pour exécuter le nouveau processus
Consultez _doserrno, errno, _sys_errlist, et _sys_nerr pour plus d'informations sur ces éléments, et autres, les codes de retour.
Notes
Chacune de ces fonctions crée et exécute un nouveau processus, en passant un tableau de pointeurs vers des arguments de ligne de commande et un tableau de pointeurs vers les paramètres d'environnement.Ces fonctions utilisent la variable d'environnement d' PATH pour rechercher le fichier à exécuter.
Ces fonctions valident leurs paramètres.Si cmdname ou argv est un pointeur null, ou si les points d' argv au pointeur null, ou l' argv[0] est une chaîne vide, le gestionnaire de paramètre non valide est appelé, comme décrit dans Validation des paramètres .Si est autorisé à l'exécution pour continuer, ces fonctions par errno définir le retour à EINVAL, et -1.Aucun nouveau processus n'a engendré.
Configuration requise
Routine |
En-tête requis |
---|---|
_spawnvpe |
<stdio.h> ou <process.h> |
_wspawnvpe |
<stdio.h> ou <wchar.h> |
Pour des informations de compatibilité supplémentaires, consultez l' Compatibilité dans l'introduction.
Exemple
Consultez l'exemple de _spawn, fonctions de _wspawn.