如何使用mingw-w64编译和链接32位Windows可执行文件

我正在使用Ubuntu 13.04,并使用安装了mingw-w64 apt-get install

mingw-w64。我可以使用以下命令来编译和链接程序的64位工作版本:

x86_64-w64-mingw32-g++ code.cpp -o app.exe

生成一个64位的 app.exe 文件。

我使用哪些二进制或命令行标志来生成32位版本的app.exe?

回答:

这取决于您当前正在使用哪种工具链。既 DWARF 和_SEH_变体(它们来自GCC4.8.0开始)仅单一目标。您可以通过检查其发行版的目录结构来自己查看,即它们仅包含具有64位和32位寻址的库,而不能同时包含两者。另一方面,普通的旧

SJLJ 发行版确实是双重目标,并且为了构建32位目标,只需提供-m32标志。如果那行不通,那就用构建i686-w64-mingw32-g++

回答:


顺便说一句,实现每个 GCC异常模型 的三个相应的 动态链接库 (DLL)是 __

  1. libgcc_s_dw2-1.dll (侏儒);
  2. libgcc_s_seh-1.dll (SEH);
  3. libgcc_s_sjlj-1.dll (SJLJ)。

因此,要找出您当前的MinGW-w64发行版到底提供了什么异常模型,您可以

  1. 检查MinGW-w64安装的目录和文件结构,以期找到其中一个DLL(通常位于中bin);要么
  2. 构建一些涉及异常处理的实际或测试C ++代码,以强制与其中一个DLL进行链接,然后查看所构建的目标依赖于这些DLL中的哪个(例如,可以在Windows 上的Dependency Walker中看到);要么
  3. 采用蛮力方法并编译一些测试代码以进行汇编(而不是机器代码),并寻找诸如___gxx_personality_v*(DWARF),___gxx_personality_seh*(SEH),___gxx_personality_sj*(SJLJ)之类的引用的存在;

以上是 如何使用mingw-w64编译和链接32位Windows可执行文件 的全部内容, 来源链接: utcz.com/qa/433242.html

回到顶部