共用方式為


_spawnvp, _wspawnvp

建立處理序並加以執行。

重要

這個 API 不能用於在 Windows 執行階段中執行的應用程式。 如需詳細資訊,請參閱 CRT functions not supported in Universal Windows Platform apps (通用 Windows 平台應用程式中不支援的 CRT 函式)。

語法

intptr_t _spawnvp(
   int mode,
   const char *cmdname,
   const char *const *argv
);
intptr_t _wspawnvp(
   int mode,
   const wchar_t *cmdname,
   const wchar_t *const *argv
);

參數

mode
呼叫此處理序的執行模式。

cmdname
待執行檔案的路徑。

argv
引數指標的陣列。 自變數 argv[0] 通常是真實模式中路徑的指標,或是受保護模式中的程式名稱指標,而 argv[1] 透過 argv[n] 是形成新自變數清單的字元字串指標。 自變數必須是NULL標記自變數argv[n+1]清單結尾的指標。

傳回值

同步 _spawnvp_wspawnvp (為 mode 指定的 _P_WAIT) 的傳回值是新處理序的結束狀態。 非同步 _spawnvp_wspawnvp (為_P_NOWAIT 指定的 _P_NOWAITOmode) 的傳回值是處理序控制代碼。 如果處理序正常終止,結束狀態為 0。 如果繁衍的處理序明確使用非零引數呼叫 exit 常式,您就可以將結束狀態設為非零值。 如果新進程未明確設定正結束狀態,則正結束狀態表示中止或中斷異常結束。 -1 的傳回值表示錯誤(未啟動新進程)。 在這種情況下, errno 會設為下列其中一個值:

Description
E2BIG 引數清單超過 1024 個位元組。
EINVAL mode 引數無效。
ENOENT 找不到檔案或路徑。
ENOEXEC 指定的檔案不是可執行檔,或具有無效的可執行檔格式。
ENOMEM 可用記憶體不足,無法執行新處理序。

如需傳回碼的詳細資訊,請參閱errno_doserrno_sys_errlist_sys_nerr

備註

這些函式中的每一個都會產生新程序並加以執行,並且將指標的陣列傳遞至命令列引數,以及使用 PATH 環境變數尋找要執行的檔案。

這些函式會驗證它們的參數。 cmdname如果 或 argv 為 Null 指標,或argv指向 Null 指標,或argv[0]為空字串,則會叫用無效的參數處理程式,如參數驗證中所述。 如果允許繼續執行,這些函式會將 errno 設為 EINVAL,並傳回 -1。 未繁衍任何新處理序。

根據預設,此函式的全域狀態會限定於應用程式。 若要變更此行為,請參閱 CRT 中的全域狀態

需求

常式 必要的標頭
_spawnvp <stdio.h> 或 <process.h>
_wspawnvp <stdio.h> 或 <wchar.h>

如需相容性詳細資訊,請參閱相容性

範例

請參閱中的範例, _spawn_wspawn 函式

另請參閱

進程和環境控制
_spawn_wspawn 函式
abort
atexit
_exec_wexec 函式
exit、 、 _Exit_exit
_flushall
_getmbcp
_onexit, _onexit_m
_setmbcp
system, _wsystem