windows - Cygwin和MinGW有什么区别?

我想让我的C ++项目跨平台,我正在考虑使用Cygwin / MinGW。 但是他们之间有什么区别呢?

另一个问题是,如果没有Cygwin / MinGW,我能否在系统上运行二进制文件?

Answers


Cygwin是尝试在Windows上创建一个完整的UNIX / POSIX环境。 要做到这一点,它使用各种DLL。 虽然这些DLL被GPLv3 +覆盖,但是它们的许可证包含一个异常 ,不会强制派生的工作被GPLv3 +覆盖。 MinGW是一个C / C ++编译器套件,它允许您创建Windows可执行文件而不依赖于这样的DLL - 您只需要普通的MSVC运行时,这是Microsoft Windows正常安装的一部分。

你也可以得到一个小的UNIX / POSIX环境,用MinGW编译成MSYS 。 它没有Cygwin的所有功能,但对于想要使用MinGW的程序员来说是非常理想的。

作为一个简化,就是这样的:

  • 在Cygwin中编译一些东西,然后编译Cygwin 。

  • 编译MinGW中的东西,你正在为Windows编译它。

关于Cygwin

Cygwin的目的是通过模拟许多基于Unix的操作系统提供的小细节,并通过POSIX标准来记录,使得基于nix的应用程序更容易移植到Windows上。 如果您的应用程序假定它可以使用Unix功能,例如管道,Unix风格的文件和目录访问等等,那么您可以在Cygwin中编译它,而Cygwin本身将作为您的应用程序的兼容层 ,这些特定于Unix的范例可以继续使用,对应用程序进行很少或不需要修改。

如果你想为Cygwin编译一些东西并分发这个应用程序,那么你还必须将Cygwin运行时环境(由cygwin1.dll提供)与它一起cygwin1.dll , 这对你可能使用哪种类型的软件许可有影响 。

关于MinGW

MinGW是GNU编译器工具的Windows端口,例如GCC,Make,Bash等等。 它不会试图模拟或提供与Unix的全面兼容性,而是提供在Windows上使用GCC(GNU编译器)和少量其他工具的最低必要环境。 它没有像Cygwin一样的Unix仿真层,但是结果是你的应用程序需要特别的编程才能在Windows上运行,这可能意味着如果它被创建为依赖于在标准Unix环境中运行,使用Unix特有的功能,比如前面提到的功能。 默认情况下,在MinGW的GCC中编译的代码将编译为本机Windows X86目标,包括.exe和.dll文件,但是也可以使用正确的设置进行交叉编译。 MinGW是Microsoft Visual C ++编译器及其关联的链接/制作工具的开源替代品。

存在相当复杂的跨平台框架,这使得将应用轻松移植到各种操作系统的任务成为可能 - 例如Qt框架是跨平台应用的流行框架。 如果您从一开始就使用这样的框架,那么您不仅可以减少在移植到其他平台时遇到的麻烦,而且可以在所有平台上使用相同的图形窗口小部件(窗口,菜单和控件) GUI应用程序。

要添加到其他答案,Cygwin附带MinGW库和标题,您可以通过使用-mno-cygwin标志与gcc编译而不链接到cygwin1.dll。 我非常喜欢使用简单的MinGW和MSYS。

维基百科在这里做一个比较。

从Cygwin的网站 :

  • Cygwin是一个类似于Linux的Linux环境。 它由两部分组成:一个DLL(cygwin1.dll),充当Linux API仿真层,提供大量的Linux API功能。
  • 提供Linux外观的一系列工具。

从Mingw的网站 :

MinGW(简称“GNU for Windows”)是一个可免费获得并可自由分发的Windows特定头文件和导入库的集合,与GNU工具集相结合,可以生成不依赖任何第三方C运行时DLL的本地Windows程序

Cygwin使用DLL,cygwin.dll(或者一组DLL)在Windows上提供类似于POSIX的运行时。

MinGW编译为本机Win32应用程序。

如果你用Cygwin构建一些东西,你安装它的任何系统也将需要Cygwin DLL。 MinGW应用程序不需要任何特殊的运行时。

阅读这些回答的问题,了解Cygwin和MinGW之间的区别。

问题1:我想创建一个我编写源代码的应用程序,编译一次并在任何平台(例如Windows,Linux和Mac OS X ...)中运行它。

解答#1:用JAVA写你的源代码。 编译一次源代码并在任何地方运行。

问题2:我想创建一个我编写源代码的应用程序,但没有任何问题,我可以分别编译任何平台的源代码(例如Windows,Linux和Mac OS X ...)。

答案2:用C或C ++写你的源代码。 只使用标准头文件。 为任何平台使用合适的编译器(例如Windows的Visual Studio,Linux的GCC和Mac的XCode)。 请注意,您不应该使用任何高级编程功能在所有平台上成功编译您的源代码。 如果您不使用C或C ++标准类或函数,则您的源代码不能在其他平台中编译。

问题#3:在问题#2的回答中,每个平台都难以使用不同的编译器,有没有跨平台的编译器?

答案3:是的,使用GCC编译器。 这是一个跨平台的编译器。 要在Windows中编译源代码,请使用为Windows提供GCC编译器的MinGW ,并将源代码编译为本机Windows程序。 不要使用任何高级编程功能(如Windows API)在所有平台上成功编译源代码。 如果您使用Windows API函数,则您的源代码不会在其他平台中编译。

问题4:C或C ++标准头文件不提供任何高级编程功能,如多线程。 我能做什么?

答案4:您应该使用POSIX(便携式操作系统接口[用于UNIX])标准。 它提供了许多高级编程功能和工具。 许多操作系统完全或部分POSIX兼容(如Mac OS X,Solaris,BSD / OS和...)。 一些操作系统,虽然没有正式认证为POSIX兼容,很大程度上符合(如Linux,FreeBSD,OpenSolaris和...)。 Cygwin为Microsoft Windows提供了一个基本符合POSIX标准的开发和运行环境。

从而:

要在Windows中使用GCC跨平台编译器的优势,请使用MinGW。

要利用Windows中的POSIX标准高级编程功能和工具的优势,请使用Cygwin。

维基百科说 :

MinGWCygwin 1.3.3版本中分离出来。 虽然CygwinMinGW都可以用来将UNIX软件移植到Windows ,但他们有不同的方法: Cygwin目标是提供一个完整的POSIX layer ,提供Linux , UNIXBSD变种中存在的几个系统调用和库的模拟。 POSIX layer运行在Windows之上,为了兼容性而牺牲性能。 因此,这种方法需要使用Cygwin编写的Windows程序运行在必须与程序一起分发的copylefted兼容性库的顶部,以及程序的source code 。 MinGW旨在通过直接的Windows API calls提供原生的功能和性能。 与Cygwin不同, MinGW不需要兼容层DLL ,因此程序不需要与source code一起分发。

由于MinGW依赖于Windows API calls ,因此无法提供完整的POSIX API ; 它无法编译一些可以用Cygwin编译的UNIX applications 。 具体而言,这适用于需要POSIX功能(如fork() , mmap()ioctl()以及期望在POSIX environment运行的应用程序。 使用本身已经移植到MinGWcross-platform library (例如SDL , wxWidgets , QtGTK+编写的应用程序通常在MinGW编译将像在Cygwin那样容易。

MinGWMSYS的组合提供了一个小型自包含的环境,可以将其加载到可移动媒体上,而无需在注册表或计算机上的文件中留下条目。 Cygwin Portable提供了类似的功能。 通过提供更多的功能, Cygwin安装和维护变得更加复杂。

也可以MinGW-GCC under POSIX systemsMinGW-GCC under POSIX systems cross-compile Windows applications 。 这意味着开发人员不需要使用MSYS进行Windows安装来编译在没有Cygwin情况下在Windows运行的软件。

从移植C程序的角度来看,理解这个的一个好方法就是举个例子:

#include <sys/stat.h>
#include <stdlib.h> int main(void)
{
struct stat stbuf;
stat("c:foo.txt", &stbuf);
system("command");
printf("Hello, World\n");
return 0;
}

如果我们把stat _stat ,我们可以用Microsoft Visual C编译这个程序。我们也可以用MinGW和Cygwin来编译这个程序。

在Microsoft Visual C下,该程序将链接到MSVC可再发行的运行时库: mxvcrtnn.dll ,其中nn是某个版本的后缀。 为了发布这个程序,我们将不得不包含该DLL。 该DLL提供了_stat , systemprintf 。

在MinGW下,该程序将链接到msvcrt.dll ,这是一个内部的,未公开的,未版本化的库,是Windows的一部分,禁止应用程序使用。 该库本质上是来自MS Visual C的可再发行的运行时库的一个分支,供Windows本身使用。

在这两种情况下,该计划将有类似的行为:

  • stat函数将返回非常有限的信息 - 例如,没有有用的权限或inode编号。
  • 根据与驱动器c:相关联的当前工作目录来解析路径c:file.txt 。
  • system使用cmd.exe /c来运行外部命令。

我们也可以编译Cygwin下的程序。 类似于MS Visual C使用的可再发行的运行时,Cygwin程序将被链接到Cygwin的运行时库: cygwin1.dll (Cygwin proper)和cyggcc_s-1.dll(GCC运行时支持)。 由于Cygwin现在在LGPL之下,即使它不是GPL兼容的免费软件,我们也可以用我们的程序打包,并运行程序。

在Cygwin下,库函数的行为将有所不同:

  • stat函数具有丰富的功能,在大多数字段中返回有意义的值。
  • 路径c:file.txt完全不理解为包含驱动器号引用,因为c:后面没有斜杠。 冒号被认为是名字的一部分,并以某种方式破坏了它。 在Cygwin中没有针对卷或驱动器的相对路径的概念,没有“当前记录的驱动器”概念,也没有每个驱动器当前的工作目录。
  • system函数尝试使用/bin/sh -c解释器。 Cygwin将根据您的可执行文件的位置来解析/路径,并希望sh.exe程序与您的可执行文件位于sh.exe位置。

Cygwin和MinGW都允许你使用Win32函数。 如果你想调用MessageBoxCreateProcess ,你可以这样做。 你也可以在MinGW和Cygwin下使用gcc -mwindows轻松地创建一个不需要控制台窗口的程序。

Cygwin不是严格的POSIX。 除了提供对Windows API的访问之外,它还提供了一些Microsoft C函数(在msvcrt.dll找到的东西或可重新分发的msvcrtnn.dll运行时)的自己的实现。 一个例子就是spawn*系列的spawn*系列。 这些在Cygwin上使用而不是forkexec是一个好主意,因为它们更好地映射到没有fork概念的Windows进程创建模型。

从而:

  • Cygwin程序并不比MS Visual C程序“本地化”,理由是需要库的伴随。 Windows上的编程语言实现需要提供自己的运行时,甚至是C语言实现。 Windows上没有“libc”供公众使用。

  • MinGW不需要第三方DLL的事实实际上是一个缺点, 它取决于Visual C运行时的未公开的Windows内部分支。 MinGW这样做是因为GPL系统库异常适用于msvcrt.dll ,这意味着可以使用MinGW编译和重新分发GPL编程的程序。

  • 由于与msvcrt.dll相比,对POSIX的更广泛和更深入的支持,Cygwin是迄今为止移植POSIX程序的优越环境。 由于它现在在LGPL之下,所以它允许具有各种许可的应用程序(开放源代码或封闭源代码)被重新分配。 Cygwin甚至包含VT100仿真和termios ,它们与Microsoft控制台一起使用! 使用tcsetattr设置原始模式并使用VT100代码来控制光标的POSIX应用程序将在cmd.exe窗口中正常工作。 就最终用户而言,这是一个本机控制台应用程序,使Win32调用来控制控制台。

然而:

  • 作为一个本地的Windows开发工具,Cygwin有一些怪癖,比如Windows的外部路径处理,依赖于像/bin/sh类的硬编码路径和其他问题。 这些差异是使Cygwin程序“非本地”的。 如果程序将路径作为参数或从对话框输入,则Windows用户期望该路径的工作方式与其他Windows程序中的路径相同。 如果不这样做,那就是个问题。

插件:在LGPL宣布后不久,我启动了Cygnal (Cygwin本地应用程序库)项目,以提供一个旨在解决这些问题的Cygwin DLL的分支。 程序可以在Cygwin下开发,然后使用Cygnal版本的cygwin1.dll进行部署,而无需重新编译。 随着这个库的改进,它将逐渐消除对MinGW的需求。

当Cygnal解决路径处理问题时,可以开发一个单独的可执行文件作为Windows应用程序与Cygnal一起使用时,与Cygwin的/usr/bin下安装Cygwin路径无缝工作与Windows路径。 在Cygwin下,可执行文件将透明地处理/cygdrive/c/Users/bob类的路径。 在Cygnal版本的cygwin1.dll链接的本地部署中,该路径将没有任何意义,而它将理解c:foo.txt 。

不要忽视AT&T的U / Win软件,该软件可以帮助您在Windows上编译Unix应用程序(最新版本 - 2012-08-06;使用Eclipse公共许可证,版本1.0)。

像Cygwin一样,他们必须跑到一个图书馆。 在他们的情况下POSIX.DLL 。 AT&T的工作人员是非常棒的工程师(同样的团队给你带来了ksh和dot ),他们的东西值得一试。

Cygwin模拟整个POSIX环境,而MinGW只是编译的最小工具集(编译本地Win应用程序)。所以如果你想让你的项目跨平台,两者之间的选择是明显的,MinGW。

虽然你可能会考虑在Windows上使用VS,在Linux / Unices上使用GCC。 大多数开源项目都是这样做的(例如Firefox或Python)。

请注意,效用行为可以真正在两者之间变化。

例如,Cygwin tar可以fork - 因为fork()在DLL中被支持,而mingw版本则不能。 尝试从源代码编译mysql时,这是一个问题。

要在商业/专有/非开源应用程序中使用Cygwin,您需要从Red Hat获得“ 许可证买断 ”的数万美元; 这使标准许可条款以相当大的成本无效。 谷歌“cygwin许可证费用”,看到前几个结果。

对于mingw,这样的成本是不会发生的,许可证(PD,BSD,MIT)是非常宽容的。 您至多可能需要为您的应用程序提供许可证详细信息,例如使用mingw64-tdm时所需的winpthreads许可证。

编辑感谢Izzy向日葵:商业许可证不再是可用的或必要的,因为在Cygwin的winsup子目录中找到的API库现在正在 LGPL下分发 ,而不是完整的GPL。

Cygwin旨在为Windows提供一个或多或少完整的POSIX环境,其中包括一套广泛的工具,旨在提供一个完整的类Linux平台。 相比之下,MinGW和MSYS提供了一个轻量级的,极简主义的类POSIX层,只有像gccbash这样的更重要的工具可用。 由于MinGW更简约的方法,它不提供Cygwin提供的POSIX API覆盖的程度,因此不能构建某些可以在Cygwin上编译的程序。

根据两者生成的代码,Cygwin工具链依赖动态链接到一个大的运行时库cygwin1.dll ,而MinGW工具链将代码编译为二进制文件,动态链接到Windows本机C库msvcrt.dll以及静态地glibc部分。 Cygwin可执行文件因此更为紧凑,但需要单独的可再发行DLL,而MinGW二进制文件可以独立运行,但往往会更大。

基于Cygwin的程序需要单独运行的DLL也会导致许可限制。 Cygwin运行时库在GPLv3下获得许可,对于具有OSI兼容许可的应用程序,链接例外,因此希望围绕Cygwin构建闭源应用程序的开发者必须从Red Hat获得商业许可。 另一方面,MinGW代码可以用于开放源码和封闭源码的应用程序,因为头文件和库文件是被许可的。

Cygwin是一个类似于Unix的环境和Microsoft Windows的命令行界面。

Mingw是GNU编译器集合(GCC)到Microsoft Windows的原生软件端口,还有一套可自由分发的用于Windows API的导入库和头文件。 MinGW允许开发人员创建本机Microsoft Windows应用程序。

只要所有必要的库(DLL)都存在,您就可以在不使用cygwin环境的情况下运行使用mingw生成的二进制文件。

Cygwin使用兼容性层,而MinGW是本地的。 这是不同的。

https://code.i-harness.com/zh-CN/q/bc6ac

windows - Cygwin和MinGW有什么区别?(MinGW从Cygwin 1.3.3版本中分离出来)的更多相关文章

  1. windows上安装gcc/g++环境(MinGW,msys64等)

    1 前言 经过折腾安装gcc环境,记录一下 2 工具  MinGW安装器: 下载地址1:MinGW官网 下载地址2:SourceForge (MinGW w64) 下载地址3:win-builds-1 ...

  2. Cygwin、MinG、MSys区别与联系(转)

    转自:https://www.biaodianfu.com/cygwin-ming-msys.html 什么是Cygwin? Cygwin,原Cygnus出品(已被红帽收购),目前是RedHat名下的 ...

  3. linux和windows动态库加载路径区别

    # linux和windows动态库加载路径区别 ### 简介------------------------------ linux加载动态库的路径是系统目录/lib和/usr/lib.- wind ...

  4. php windows与linux下的路径区别

    php windows与linux下的路径区别windows用的是"\",linux用的是"/"这一点要特别清楚,, ps:在PHP windows也可以用/表 ...

  5. Linux中要重启apache服务与在windows是有很大的区别,下面我们来介绍一下

    在Linux中要重启apache服务与在windows是有很大的区别,下面我们来介绍一下常用的命令,需要的朋友参考下吧(http://www.hnkjlb.com) linux系统为Ubuntu 一. ...

  6. 深入剖析Windows专业版安装Docker引擎和Windows家庭版Docker引擎安装的区别

    原创声明:作者:Arnold.zhao  博客园地址:https://www.cnblogs.com/zh94 公司使用的电脑是Windows专业版,所以配置本机的Docker时会方便许多,后续由于需 ...

  7. 与众不同 windows phone (37) - 8.0 文件系统: StorageFolder, StorageFile, 通过 Uri 引用文件, 获取 SD 卡中的文件

    [源码下载] 与众不同 windows phone (37) - 8.0 文件系统: StorageFolder, StorageFile, 通过 Uri 引用文件, 获取 SD 卡中的文件 作者:w ...

  8. linux 版本中 i386/i686/x86-64/pcc 等的区别

    在查看dpdk官方文档的时候,发现有 这样(kernel - devel.x86_64; kernel - devel.ppc64:glibc.i686)这样的安装包信息,收集了点资料来分析这三者的关 ...

  9. python2.* 版本 与 3.* 版本中的区别

    目录 Unicode编码 print函数 raw_input() 和 input( ) 不等运算符 数据类型 除法 map 和 filter Unicode编码 python2.x 解释器默认编码格式 ...

随机推荐

  1. ajax 通过return 返回data值

    方法例如以下: 1. ajax 必须为同步 设置async:false 2. 定一个局部变量 把data赋值给局部变量 然后 return 局部变量就可以 示比例如以下 function getEmp ...

  2. 微服务实战(三):深入微服务架构的进程间通信 - DockOne.io

    原文:微服务实战(三):深入微服务架构的进程间通信 - DockOne.io [编者的话]这是采用微服务架构创建自己应用系列第三篇文章.第一篇介绍了微服务架构模式,和单体式模式进行了比较,并且讨论了使 ...

  3. 防止 Chrome 屏蔽 非官方 扩展程序 教程(一)

    说明 Google Chrome,又称 Google 浏览器,是一个由 Google(谷歌)公司开发的网页浏览器.该浏览器是基于其它开源软件所撰写.包含 WebKit,目标是提升稳定性.速度和安全性. ...

  4. Android OnGestureListener用法 识别用户手势 左右滑动

    Android可以识别用户的手势(即用户用手指滑动的方向),通过用户不同的手势,从而做出不同的处理 需要使用OnGestureListener 比如说看电子书的时候翻页,或者要滑动一些其他内容 直接上 ...

  5. matlab无法使用

    mathlab前一段时间使用不了,网上找到了一些出来方法. (1)修改本地时间,将本地时间改都较前的时间,就可以了, (2)使用网上的一个文件,将自己的文件替换掉就可以了 文件放在我的百度云盘里面ht ...

  6. [arm]虚拟机,2440开发板,主机三者互通

    想实现3着互通先必须保证三者的网段是相同的: 首先查看电脑主机的IP: 然后再看看虚拟机的IP: 惊喜的发现,他们在一个网段上---那就不用改了-- 再去看看开发板上的IP: 这里注意,输入命令时,是 ...

  7. 【例题3-3 UVA - 401】Palindromes

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 如果一个字符没有对应的镜像,那么它对应的是一个空格. 然后注意 aba这种情况. 这种情况下b也要查一下它的镜像是不是和b一样. [ ...

  8. 【22.95%】【hdu 5992】Finding Hotels

    Problem Description There are N hotels all over the world. Each hotel has a location and a price. M ...

  9. [Node] Using dotenv to config env variables

    Install: npm install dotenv --save For example, we can store the sensitive information or env relate ...

  10. 用Eclipse替代Keil&IAR来开发ARM应用(升级版)

    Eclipse GNU ARM Plugin 2014/7/16 作者 kiya 几个月前写了一篇<),想自己丰衣足食的参考我的上一篇文章,以及GNU ARM的官网. 用Eclipse替代Kei ...