J T*_*J T 3 c++ linker visual-studio-2005
我出现了一个非常奇怪的链接器错误:
link.exe : fatal error LNK1107: invalid or corrupt file: cannot read at 0x270
Run Code Online (Sandbox Code Playgroud)
但这很奇怪,因为通常错误消息会告诉您哪些对象无效或已损坏.换句话说,通常此错误消息看起来像这样:
myDLL.dll : fatal error LNK1107: ....
Run Code Online (Sandbox Code Playgroud)
但是,在这种情况下,无效对象是正在运行的应用程序本身(link.exe)!
我已经尝试用另一个我知道有效的副本替换可执行文件.同样的错误.
我正在运行的命令是这样的:
../vendor/microsoft/msdev80_2005/VC/bin/link.exe /NOLOGO /SUBSYSTEM:CONSOLE /LIB
PATH:../vendor/microsoft/msdev80_2005/VC/atlmfc/lib /LIBPATH:../vendor/microsoft
/msdev80_2005/VC/lib /LIBPATH:../vendor/microsoft/msdev80_2005/VC/PlatformSDK/Li
b /LIBPATH:lib/win32/dbg /OUT:bin/win32/dbg/bugshow.exe Advapi32.lib ws2_32.lib
bugshow/obj/win32/dbg/main.o libA.lib libB.lib libC.lib libD.lib
Run Code Online (Sandbox Code Playgroud)
main.o正在使用以下编译器指令进行编译:
../vendor/microsoft/msdev80_2005/VC/bin/cl.exe /nologo /X /w /EHsc -I../vendor/m
icrosoft/msdev80_2005/VC/atlmfc/include -I../vendor/microsoft/msdev80_2005/VC/in
clude -I../vendor/microsoft/msdev80_2005/VC/PlatformSDK/Include /D_WIN32 /DBOOST
_USE_WINDOWS_H /DWIN32_LEAN_AND_MEAN /D_WIN32_WINNT=0x0501 /DBOOST_THREAD_USE_LI
B /DBOOST_ALL_NO_LIB /D_CRT_SECURE_NO_DEPRECATE /D_CRT_NONSTDC_NO_DEPRECATE /Z7
/MTd /c -I../vendor/boost.org/boost/1.45.0/include /Fobugshow/obj/win32/dbg/main.o
bugshow/main.cpp
Run Code Online (Sandbox Code Playgroud)
任何想法为什么link.exe会像这样失败?
更新:
当我将link.exe所在的文件夹添加到我的PATH,然后调用没有路径前缀的link.exe时,我收到以下错误:
LINK: fatal error LNK1181: cannot open input file 'link.exe'
Run Code Online (Sandbox Code Playgroud)
为什么link.exe如此拼命地打开自己??!?!
我解决了这个问题!
MSVC链接器在Microsoft的MSDN页面上使用了一个令人讨厌的小环境变量(在此处描述).它说:
LINK, if defined, prepends arguments in the command line.
Run Code Online (Sandbox Code Playgroud)
我的系统具有由我安装的最近的应用程序LINK定义的环境变量STATIC.这导致link.exe解释自身的命令行实例,如下所示:
STATIC link.exe /NOLOGO /SUBSYSTEM:CONSOLE ...
Run Code Online (Sandbox Code Playgroud)
换句话说,*argv[1]实际上通常是第一个命令行参数link.exe.它基本上将所有参数减少了一个偏移量.这反过来导致link.exe尝试将自己解释为其第一个输入文件!
绝对是令人难以置信的令人沮丧和难以察觉的问题......