MinGW-w64 工具链(GCC 编译器) 的不同构建版本的区别
下载Mingw是有很多不同的名称,有啥区别?
-
i686-15.2.0-release-mcf-dwarf-ucrt-rt_v13-rev0.7z
sha256:3a7de8f3e0e8a206b0e0bb48ba009d83317a8ccd9ca171a5dcfa40edae97e44a
95.9 MBAug 13 -
i686-15.2.0-release-posix-dwarf-msvcrt-rt_v13-rev0.7z
sha256:52315cbcc65ab01eb9d5c9cfd1904fafeb1ad302b1233982b95287b5939df764
95.9 MBAug 13 -
i686-15.2.0-release-posix-dwarf-ucrt-rt_v13-rev0.7z
sha256:8559c1e27c48f139400b4d7da848ca30a7bdb9f1fbe06e241b1b53baa6149d2a
95.8 MBAug 13 -
i686-15.2.0-release-win32-dwarf-msvcrt-rt_v13-rev0.7z
sha256:672b7dacb1b27664083b27d3f982694bf434d06f5e3b0b0e0eba4d3e710b0df7
95.9 MBAug 13 -
i686-15.2.0-release-win32-dwarf-ucrt-rt_v13-rev0.7z
sha256:22046362802c0a03af13e216fadb8018fca5cf1d649f1202b11bcb5cd1a2b091
95.9 MBAug 13 -
x86_64-15.2.0-release-mcf-seh-ucrt-rt_v13-rev0.7z
sha256:07cbd8e9931053afc046a85e0e3b2a782d83468a66ca2d31a25a385ef567ffd0
95.3 MBAug 13 -
x86_64-15.2.0-release-posix-seh-msvcrt-rt_v13-rev0.7z
sha256:9953edc0b80a25d1c41dba92956a495ae9d43b15e2ff589e6fa3ff0892d5e3d9
95.2 MBAug 13 -
x86_64-15.2.0-release-posix-seh-ucrt-rt_v13-rev0.7z
sha256:05b3361a3a3e20a5789db37fc2bb6a70d0b02e4667b5a31d9a6672ea40d22c69
95 MBAug 13 -
x86_64-15.2.0-release-win32-seh-msvcrt-rt_v13-rev0.7z
sha256:3e09304bd489f78227634cceaace80b3f3111c1280dcc1d1802b2d6120b2bfb5
95.4 MBAug 13 -
x86_64-15.2.0-release-win32-seh-ucrt-rt_v13-rev0.7z
sha256:9e9f0b912a59d2cfb3ce5a01bae4e7a05e4be4f8ff89e36e0f57606ec525525d
95.3 MBAug 13 -
Source code(zip)
Aug 13
-
Source code(tar.gz)
Aug 13
MinGW-w64 工具链(GCC 编译器)不同版本之间的区别主要体现在以下几个方面:
1. 架构(Architecture)
i686:32 位 x86 架构(即传统的 32 位 Windows 程序)。x86_64:64 位 x86 架构(现代 64 位 Windows 程序)。
2. 线程模型(Threading Model)
mcf:Multi-Call Frame(较新、较少见),是 MinGW-w64 中一种实验性或替代性的线程模型,用于支持某些特定运行时行为(如更轻量级的异常处理或协程)。但目前主流仍为posix或win32。posix:使用 POSIX 线程(pthreads)实现,通过winpthreads库在 Windows 上模拟 POSIX 线程行为。适合需要标准 C++11 多线程(如std::thread)支持的程序。win32:直接使用 Windows 原生线程 API。不依赖winpthreads,体积更小,但 C++11 多线程支持可能受限或需额外配置(旧版 GCC 可能不完全支持)。
注:
mcf是近期 MinGW-w64 引入的新线程/异常模型组合,主要用于优化某些场景下的性能或兼容性,但生态支持尚不如posix/win32成熟。
3. 异常处理机制(Exception Handling)
dwarf:DWARF 异常处理。仅适用于 32 位(i686),优点是生成的二进制较小,但 不支持与 Windows SEH 兼容的异常交互(例如不能 catch Windows 结构化异常)。seh:Structured Exception Handling(结构化异常处理)。适用于 64 位(x86_64),是 Windows 原生异常机制,性能好、兼容性强,推荐用于 64 位开发。- (32 位通常用
sjlj或dwarf,64 位用seh)
注意:
i686一般不会用seh,因为 Windows 32 位的 SEH 实现与 GCC 不完全兼容,所以 32 位多用dwarf或sjlj。
4. C 运行时库(CRT)
ucrt:Universal C Runtime,是 Windows 10 及以后的标准 C 运行时(由微软维护),推荐使用,兼容性好,支持最新 C 标准。msvcrt:旧版 Microsoft Visual C++ 运行时(如 msvcrt.dll),存在于所有 Windows 系统中,但功能较旧,不支持 C99/C11 新特性。
使用
ucrt的程序在 Windows 10+ 上无需额外部署 CRT(系统自带),但在 Windows 7/8 可能需要安装 KB2999226 补丁。
对比你的四个文件:
| 文件名 | 架构 | 线程模型 | 异常处理 | CRT | 适用场景 |
|---|---|---|---|---|---|
i686-15.2.0-release-mcf-dwarf-ucrt-rt_v13-rev0.7z | 32 位 | mcf | dwarf | ucrt | 32 位实验性构建,适合测试或特殊需求 |
x86_64-15.2.0-release-mcf-seh-ucrt-rt_v13-rev0.7z | 64 位 | mcf | seh | ucrt | 64 位实验性构建,可能用于协程或轻量级线程 |
x86_64-15.2.0-release-posix-seh-ucrt-rt_v13-rev0.7z | 64 位 | posix | seh | ucrt | 最常用推荐:支持 C++11 多线程 + 原生异常 + 新 CRT |
x86_64-15.2.0-release-win32-seh-msvcrt-rt_v13-rev0.7z | 64 位 | win32 | seh | msvcrt | 兼容老系统(如 Win7 无 UCRT 补丁),但 C++ 多线程支持弱 |
推荐选择:
- 日常开发(64 位) → 选:
x86_64-...-posix-seh-ucrt... - 需要最小依赖 / 老系统兼容 → 可考虑
win32-seh-msvcrt,但注意 C++11 线程问题 - 32 位开发 → 通常选
i686-...-posix-dwarf-ucrt...(但你列出的是mcf,可能非主流) mcf版本 → 目前属于前沿或实验性质,除非有特定需求(如使用最新 MinGW-w64 特性),否则不建议生产使用
