gpt4 book ai didi

mono - 想要: user experiences with C# (mono) on MacOS and Linux

转载 作者:行者123 更新时间:2023-12-04 17:27:53 24 4
gpt4 key购买 nike

我有一个 friend ,他是一名认真的Linux开发人员,但是现在他正在Windows上使用C#,并且非常喜欢它。我被C#吸引了,因为像Java一样,我应该能够在一个系统上编译并可以在任何地方运行。

如果您使用C#在Windows上进行开发,则使用的是dot-Net。在Linux和MacOS上,您正在使用Mono。

其他人已经发布了Mono是非常好的,不再是一个科学项目,并且Microsoft的大多数核心功能都已存在。但这并不是我真正遇到的问题。我在想:

  • Linux/MacOS上Mono的性能如何与Java相提并论?如果我想在所有三个具有相同目标代码的平台上快速运行,那么我的最佳选择是什么?
  • 将Mono与makefile一起使用并使用emacs进行开发是否容易/可行/合理?
  • MacOS和Linux中是否支持代码分解,或者我只是硬着头皮在Windows中进行所有开发,还是更好?
  • Mono与Subversion和其他开放源代码开发堆栈一起使用的效果如何? autoconf怎么样?还是这是一种完全不同的做事方式?

  • 谢谢

    最佳答案

    我已经在Linux上使用Mono大约三年了,最近已经在OS X上使用它。一些Linux内容相当广泛,但到目前为止,OS X只是一些简单的ASP.NET MVC2应用程序。

    1)Mono的性能对我而言从来都不是问题。这并不是说性能并不重要,而仅仅是Mono本身的性能从来都不是问题。我所做的很多事情都是基于Web的,因此I/O和数据库内存的使用在Mono之前就给我带来了打击。

    从历史上看,Mono的最大缺陷是垃圾收集器(GC)。我想说Java在这方面更好。 Mono的最新版本在这一领域取得了长足的进步,但在比较方面,我没有任何硬性数字可为您提供帮助。

    我确信Mono有时会更快,Java有时会更快,但我会说Java整体上会更快。

    2)您当然可以使用makefile进行Mono开发。当然,Mono团队本身也这样做。您当然也可以使用Emacs并提供一个C# mode for it

    我倾向于自己使用MonoDevelop和xbuild(msbuild的Mono版本),并且没有在Emacs中进行C#工作的经验。 MonoDevelop很棒,因为它在所有平台上都完全相同。另外,尽管我很少使用它了,但是项目格式与Visual Studio和SharpDevelop相同是很好的。

    3)MonoDevelop具有相当不错的代码分解支持。在Windows,Linux和Mac上相同。您无需使用Windows进行开发(尽管您当然可以),但是我相信使用MonoDevelop之类的IDE会更快乐。如果不习惯,甚至Intellisense之类的东西也将变得难以生存。但是集成调试,能够深入到框架,数据库集成,单元​​测试,SCM集成以及其他出色的工具支持,这些都是一站式的工作(至少对我而言)。

    4)Mono本身当然并不关心版本控制。您的源文件只是文本,您可以使用任何方法进行管理。

    也就是说,MonoDevelop在IDE中内置了出色的Subversion支持。我已经广泛使用它,这是即使在Windows上也无法脱离MonoDevelop的原因之一。 MonoDevelop的最新版本(2.6 beta)也包含Git支持。

    您没有提到单元测试,但是MonoDevelop还具有内置于IDE中的NUnit支持。我也在每个项目上都使用了它,并且效果非常好。 MonoDevelop中的版本为2.4.8(如果有内存的话),因此它不是最新版本,但效果很好。

    简而言之,Mono通常可以与开源工具很好地配合使用。对于我来说,它一直都发挥的很好。

    当然,Autoconf由Mono项目本身使用,但是作为Mono开发人员,我从未见过需要它。我努力只在我的项目中使用托管代码。这样,我在目标平台上所需的就是Mono(或.NET)。不必担心所有这些东西是Mono或Java之类的托管环境的主要好处之一。运行时本身(CLR)确保我的应用具有正常运行所需的一切。

    我知道MonoDevelop将为C/C++项目(非Mono)构建autoconf/autorun文件,但是我本人并没有做很多事情。

    至于先前的评论,Mono JIT显然已针对目标平台进行了调整。那就是进行平台特定性能调整的地方。

    就像发表评论一样,我发现从其自身的角度来看,Mono最好被视为开发环境,而不是Microsoft东西的兼容层。 Mono团队以许多有趣的方式扩展了.NET。您为Mono开发的所有内容都可以在.NET上运行,但是有些.NET功能不适用于Mono。例如,Mono不支持Windows Presentation Foundation(WPF)。您必须使用Windows Forms或GTK#来进行跨平台的GUI工作。您还可以在Mac上使用Cocoa#或MonoMac,在iPhone上使用MonoTouch或在Android上使用MonoDroid。您也可以使用Moonlight代替Silverlight,尽管我玩的还不多。

    自从您询问Java以来​​,还有一件事。我发现Java世界中有一些库在.NET世界中找不到对应的库。在这些情况下,我很幸运使用IKVM.NET将此集成到我的Mono应用程序中。 IKVM.NET也可以在.NET上运行,但是Mono和IKVM.NET非常舒适,甚至共享一些代码。

    这样就可以了,至少给您一个真正的答案。

    关于mono - 想要: user experiences with C# (mono) on MacOS and Linux,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4988666/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com