如何使用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)是 __
libgcc_s_dw2-1.dll
(侏儒);libgcc_s_seh-1.dll
(SEH);libgcc_s_sjlj-1.dll
(SJLJ)。
因此,要找出您当前的MinGW-w64发行版到底提供了什么异常模型,您可以
- 检查MinGW-w64安装的目录和文件结构,以期找到其中一个DLL(通常位于中
bin
);要么 - 构建一些涉及异常处理的实际或测试C ++代码,以强制与其中一个DLL进行链接,然后查看所构建的目标依赖于这些DLL中的哪个(例如,可以在Windows 上的Dependency Walker中看到);要么
- 采用蛮力方法并编译一些测试代码以进行汇编(而不是机器代码),并寻找诸如
___gxx_personality_v*
(DWARF),___gxx_personality_seh*
(SEH),___gxx_personality_sj*
(SJLJ)之类的引用的存在;
以上是 如何使用mingw-w64编译和链接32位Windows可执行文件 的全部内容, 来源链接: utcz.com/qa/433242.html