我正在运行一个程序,想看看它的返回代码是什么(因为它根据不同的错误返回不同的代码).
我知道在Bash中我可以通过运行来做到这一点
回声$?
在Windows上使用cmd.exe时该怎么办?
名为errorlevel
存储退出代码的伪环境变量:
echo Exit Code is %errorlevel%
此外,该if
命令具有特殊语法:
if errorlevel
详情if /?
请见.
@echo off my_nify_exe.exe if errorlevel 1 ( echo Failure Reason Given is %errorlevel% exit /b %errorlevel% )
警告:如果设置环境变量名称errorlevel
,%errorlevel%
将返回该值而不是退出代码.使用(set errorlevel=
)清除环境变量,允许errorlevel
通过%errorlevel%
环境变量访问真值.
测试ErrorLevel
适用于控制台应用程序,但正如dmihailescu暗示的那样,如果您尝试从命令提示符运行窗口化应用程序(例如基于Win32),则无法运行.窗口化应用程序将在后台运行,控件将立即返回到命令提示符(很可能ErrorLevel
为零,表示该过程已成功创建).当窗口化应用程序最终退出时,其退出状态将丢失.
但是,更简单的替代方法是使用命令提示符的START /WAIT
命令启动窗口化应用程序,而不是使用其他地方提到的基于控制台的C++启动程序.这将启动窗口化应用程序,等待它退出,然后将控制权返回到命令提示符,并设置进程的退出状态ErrorLevel
.
start /wait something.exe echo %errorlevel%
使用内置的ERRORLEVEL变量:
echo %ERRORLEVEL%
但要注意应用程序是否定义了名为ERRORLEVEL的环境变量!
如果要精确匹配错误代码(例如等于0),请使用:
@echo off my_nify_exe.exe if %ERRORLEVEL% EQU 0 ( echo Success ) else ( echo Failure Reason Given is %errorlevel% exit /b %errorlevel% )
if errorlevel 0
匹配errorlevel
> = 0.见if /?
.
使用未附加到控制台的程序时,它可能无法正常工作,因为当您认为有退出代码时,该应用程序可能仍在运行.用C++实现它的解决方案如下所示:
#include "stdafx.h"
#include "windows.h"
#include "stdio.h"
#include "tchar.h"
#include "stdio.h"
#include "shellapi.h"
int _tmain( int argc, TCHAR *argv[] )
{
CString cmdline(GetCommandLineW());
cmdline.TrimLeft('\"');
CString self(argv[0]);
self.Trim('\"');
CString args = cmdline.Mid(self.GetLength()+1);
args.TrimLeft(_T("\" "));
printf("Arguments passed: '%ws'\n",args);
STARTUPINFO si;
PROCESS_INFORMATION pi;
ZeroMemory( &si, sizeof(si) );
si.cb = sizeof(si);
ZeroMemory( &pi, sizeof(pi) );
if( argc < 2 )
{
printf("Usage: %s arg1,arg2....\n", argv[0]);
return -1;
}
CString strCmd(args);
// Start the child process.
if( !CreateProcess( NULL, // No module name (use command line)
(LPTSTR)(strCmd.GetString()), // 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 GetLastError();
}
else
printf( "Waiting for \"%ws\" to exit.....\n", strCmd );
// Wait until child process exits.
WaitForSingleObject( pi.hProcess, INFINITE );
int result = -1;
if(!GetExitCodeProcess(pi.hProcess,(LPDWORD)&result))
{
printf("GetExitCodeProcess() failed (%d)\n", GetLastError() );
}
else
printf("The exit code for '%ws' is %d\n",(LPTSTR)(strCmd.GetString()), result );
// Close process and thread handles.
CloseHandle( pi.hProcess );
CloseHandle( pi.hThread );
return result;
}
值得注意的是.BAT和.CMD文件的操作不同。
阅读https://ss64.com/nt/errorlevel.html时,请注意以下几点:
.CMD和.BAT批处理文件设置错误级别的方式之间有一个关键区别:
运行“新”内部命令:APPEND,ASSOC,PATH,PROMPT,FTYPE和SET的旧的.BAT批处理脚本仅在发生错误时设置ERRORLEVEL。因此,如果批处理脚本中有两个命令,而第一个命令失败,则即使第二个命令成功后,ERRORLEVEL仍将保持设置状态。
这会使调试问题的BAT脚本更加困难,CMD批处理脚本更加一致,并且在您运行[source]的每个命令后都会设置ERRORLEVEL。
当我执行连续的命令时,这没有使我感到悲伤,但是即使发生故障,ERRORLEVEL仍然保持不变。