我有一个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;
}
我该如何调试这样的问题?我无所适从,因为我无法完全调试程序。 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
,则一切正常。当然,我希望能够调试我的调试版本。
我继续前进,并尝试使用clang-cl和lld-link开始构建我的项目,这提供了更多的诊断输出。我开始收到有关链接不同版本的运行时库的警告。 MSVC_RUNTIME_LIBRARY设置正确,并且在CMAKE_CXX_FLAGS和CMAKE_LINKER_FLAGS中具有/ MTd标志,但是通过使用详细设置运行忍者,我可以看到/ MDd跟随了我的标志,从而覆盖了先前的运行时设置。最终,我将/ MTd附加到了CMAKE_CXX_FLAGS_DEBUG和CMAKE_CXX_FLAGS_RELEASE上,现在它是编译器和链接命令中的最后一个运行时标志,此后我就再也没有这个问题。