我正在使用Ubuntu 13.04,并使用apt-get install mingw-w64
安装了mingw-w64。我可以使用以下命令编译和链接一个可工作的64位程序版本:
x86_64-w64-mingw32-g++ code.cpp -o app.exe
如何生成一个32位版本的app.exe文件?需要使用哪些二进制或命令行标志?
使用哪些二进制或命令行标志来生成一个32位版本的app.exe文件?
我正在使用Ubuntu 13.04,并使用apt-get install mingw-w64
安装了mingw-w64。我可以使用以下命令编译和链接一个可工作的64位程序版本:
x86_64-w64-mingw32-g++ code.cpp -o app.exe
如何生成一个32位版本的app.exe文件?需要使用哪些二进制或命令行标志?
使用哪些二进制或命令行标志来生成一个32位版本的app.exe文件?
这取决于您目前使用的工具链的哪个变体。 DWARF 和 SEH 变体(从 GCC 4.8.0 开始提供)仅支持单一目标。您可以通过检查它们的发行版的目录结构来自行查看,即它们只包含具有 64 位或 32 位寻址的库,但两者都不包含。另一方面,普通的 SJLJ 发行版确实是双目标的,为了构建 32 位目标,只需使用 -m32
标志即可。如果这样无效,则只需使用 i686-w64-mingw32-g++
进行构建。
顺便说一下,实现每个 GCC 异常模型 的三个相应的 动态链接库 (DLL) 是:
libgcc_s_dw2-1.dll
(DWARF);libgcc_s_seh-1.dll
(SEH);libgcc_s_sjlj-1.dll
(SJLJ)。因此,要找出您当前的 MinGW-w64 发行版到底提供了哪种异常模型,您可以选择:
bin
中);或者___gxx_personality_v*
(DWARF)、___gxx_personality_seh*
(SEH)以及 ___gxx_personality_sj*
(SJLJ);详见获取当前GCC异常模型。