Windows表示64位可执行文件是“不受支持的16位应用程序”

问题描述 投票:0回答:1

我有一个C ++程序,该程序链接Google的WebRTC库,当我以32位为目标时,该库可以编译并成功运行,而当我以64位为目标时,则完全不起作用。经过反复试验,我创建了以下程序:

#include <media/base/adapted_video_track_source.h>

class AdaptedVideoTrackSource : rtc::AdaptedVideoTrackSource
{
public:
  void AddRef() const {}
  rtc::RefCountReleaseStatus Release() const { return rtc::RefCountReleaseStatus::kDroppedLastRef; }
  bool is_screencast() const {return false;}
  absl::optional<bool> needs_denoising() const {return false;}
  bool GetStats(webrtc::VideoTrackSourceInterface::Stats* stats) {return false;}
  webrtc::MediaSourceInterface::SourceState state() const {return webrtc::MediaSourceInterface::kLive;}
  bool remote() const {return false;}
};

int main() {
  AdaptedVideoTrackSource source;
}

此程序因以下错误而失败:enter image description here如果删除超类,则程序运行正常。

我该如何调试这样的问题?我无所适从,因为我无法完全调试程序。 dumpbin似乎认为我的webrtc库很好,但是对可执行文件说warning LNK4048: Invalid format file; ignored

构建过程中有很多步骤,我认为我无法将所有步骤都放在这里。我将CMake与ExternalProject_Add一起使用来下载和构建webrtc。我生成Ninja makefile来构建代码。这是用于链接exe的忍者规则。

rule CXX_EXECUTABLE_LINKER__Test
  command = cmd.exe /C "$PRE_LINK && "C:\Program Files\CMake\bin\cmake.exe" -E vs_link_exe --intdir=$OBJECT_DIR --rc=C:\PROGRA~2\WI3CF2~1\10\bin\100183~1.0\x64\rc.exe --mt=C:\PROGRA~2\WI3CF2~1\10\bin\100183~1.0\x64\mt.exe --manifests $MANIFESTS -- C:\PROGRA~2\MIB055~1\2017\COMMUN~1\VC\Tools\MSVC\1416~1.270\bin\Hostx64\x64\link.exe /nologo $in  /out:$TARGET_FILE /implib:$TARGET_IMPLIB /pdb:$TARGET_PDB /version:0.0  $LINK_FLAGS $LINK_PATH $LINK_LIBRARIES && $POST_BUILD"
  description = Linking CXX executable $TARGET_FILE
  restat = $RESTAT

build utest\Test.exe: CXX_EXECUTABLE_LINKER__Test utest\CMakeFiles\Test.dir\main.cpp.obj | <OTHER LIBARIES> || <OTHER LIBARIES>
  FLAGS = /DWIN32 /D_WINDOWS /GR /EHsc /bigobj /Zi /Ob0 /Od /RTC1 -MTd
  LINK_FLAGS = /machine:x64 /debug /INCREMENTAL /subsystem:console
  LINK_LIBRARIES = <OTHER LIBARIES> webrtc_bundle.lib <OTHER LIBRARIES>
  LINK_PATH = -LIBPATH:D:\Folder\install64\lib
  OBJECT_DIR = utest\CMakeFiles\Test.dir
  POST_BUILD = cd .
  PRE_LINK = cd .
  TARGET_COMPILE_PDB = utest\CMakeFiles\Test.dir\
  TARGET_FILE = utest\Test.exe
  TARGET_IMPLIB = utest\Test.lib
  TARGET_PDB = utest\Test.pdb

这是私人代码,因此我重命名了我构建的可执行文件,并用<OTHER LIBARIES>替换了非webrtc库。

这是我用来构建webrtc的args.gn:

target_cpu="x64"
rtc_enable_protobuf=true
is_official_build=false
rtc_build_examples=false
rtc_include_tests=false
enable_iterator_debugging=true
is_clang=false

而且,我编写了自己的BUILD.gn文件,将webrtc与Google的构建系统可以构建的其他库捆绑在一起。

UPDATE

我发现我可以手动链接我的obj文件并制作一个完美的exe。然后,我开始研究由CMake生成的Ninja Makefile,并尝试使用链接器规则。我发现,如果从链接器标志中删除/debug,则一切正常。当然,我希望能够调试我的调试版本。

c++ windows linker webrtc 64-bit
1个回答
0
投票

我继续前进,并尝试使用clang-cl和lld-link开始构建我的项目,这提供了更多的诊断输出。我开始收到有关链接不同版本的运行时库的警告。 MSVC_RUNTIME_LIBRARY设置正确,并且在CMAKE_CXX_FLAGS和CMAKE_LINKER_FLAGS中具有/ MTd标志,但是通过使用详细设置运行忍者,我可以看到/ MDd跟随了我的标志,从而覆盖了先前的运行时设置。最终,我将/ MTd附加到了CMAKE_CXX_FLAGS_DEBUG和CMAKE_CXX_FLAGS_RELEASE上,现在它是编译器和链接命令中的最后一个运行时标志,此后我就再也没有这个问题。

© www.soinside.com 2019 - 2024. All rights reserved.