我遇到了一个非常奇怪的行为,旧的批处理文件在Windows XP下运行良好。在cmd窗口中通过批处理文件编译(Vs2017 + Win10)下的hello.c
这样的简单文件时,为什么不能正常工作?
当意识到Win10有新的安全策略时,我在微软的网站上阅读了一些文章。他们建议使用开发人员命令行窗口进行命令行编译。
实际上,手动操作效果很好。但是当我以超级管理员身份登录Win10并尝试通过批处理文件运行所有内容时,它无法正常运行,只是完成了环境配置。
手动运行批处理文件中的命令时,一切都按预期工作(成功生成可执行文件)。这有什么问题?
以下是批处理文件的内容:
%comspec% /k "C:\Program Files(x86)\Microsoft Visual Studio\2017 \Community\VC\Auxiliary\Build\vcvars64.bat"
cd g:\testdir
g:
cl TestBatFileCompile.c
初步说明:
set VSCMD_DEBUG=3
之前运行它,用于详细输出)。查看[MS.Docs]: Build C/C++ code on the command line了解更多详情为了更清晰,我增强/简化了您的示例:
script.bat:
@echo off
echo Running vcvars...
%comspec% /K "c:\Install\x86\Microsoft\Visual Studio Community\2017\VC\Auxiliary\Build\vcvarsall.bat" x64
echo Ran vcvars: %ERRORLEVEL%
echo Running cl...
cl /nologo dummy.c /link /NOLOGO
echo Ran cl: %ERRORLEVEL%
dummy.c:
int main() {
return 0;
}
输出:
e:\Work\Dev\StackOverflow\q053523085>dir /b dummy.c script.bat e:\Work\Dev\StackOverflow\q053523085>script.bat Running vcvars... ********************************************************************** ** Visual Studio 2017 Developer Command Prompt v15.9.2 ** Copyright (c) 2017 Microsoft Corporation ********************************************************************** [vcvarsall.bat] Environment initialized for: 'x64' e:\Work\Dev\StackOverflow\q053523085>rem HMMM, SOMETHING DOESN'T SEEM QUITE RIGHT. LET'S TRY EXITING CMD... e:\Work\Dev\StackOverflow\q053523085>exit Ran vcvars: 0 Running cl... 'cl' is not recognized as an internal or external command, operable program or batch file. Ran cl: 9009
发生了什么?
cmd /K
([MS.Docs]: Cmd)在现有的实例之上打开了一个新的cmd实例(使用相同的窗口)
vcvarsall在这个(第二个)实例中调用,完成了它的工作并完成了,事情似乎已经悬空要使工作正常,请使用[MS.Docs]: call调用vcvarsall:
call "c:\Install\x86\Microsoft\Visual Studio Community\2017\VC\Auxiliary\Build\vcvarsall.bat" x64
输出(在新的cmd窗口中):
e:\Work\Dev\StackOverflow\q053523085>dir /b dummy.c script.bat e:\Work\Dev\StackOverflow\q053523085>script.bat Running vcvars... ********************************************************************** ** Visual Studio 2017 Developer Command Prompt v15.9.2 ** Copyright (c) 2017 Microsoft Corporation ********************************************************************** [vcvarsall.bat] Environment initialized for: 'x64' Ran vcvars: 0 Running cl... dummy.c Ran cl: 0 e:\Work\Dev\StackOverflow\q053523085>dir /b dummy.c dummy.exe dummy.obj script.bat