微软现在拥有.NET Core、.NET Framework和Xamarin(Mono)这三种平台。
看起来它们之间存在很多重叠。那么这些不同类型的.NET平台之间有何区别?在我的项目中,我应该选择使用.NET Core而不是.NET Framework或Xamarin吗?
微软现在拥有.NET Core、.NET Framework和Xamarin(Mono)这三种平台。
看起来它们之间存在很多重叠。那么这些不同类型的.NET平台之间有何区别?在我的项目中,我应该选择使用.NET Core而不是.NET Framework或Xamarin吗?
1. 跨平台需求
如果您的目标是拥有一个能够在多个平台(Windows、Linux和MacOS)上运行的应用程序(Web/服务),那么在.NET生态系统中最好的选择就是使用.NET Core作为其运行时(CoreCLR)和库是跨平台的。另一种选择是使用Mono项目。
这两种选择都是开源的,但.NET Core直接由Microsoft官方支持,并且将来会有大量投入。
在跨平台使用.NET Core时,在Windows上使用Visual Studio IDE可以获得最佳的开发体验,它支持许多生产力功能,包括项目管理、调试、源代码控制、重构、富编辑(包括Intellisense)、测试等等。但是,使用Visual Studio Code在Mac、Linux和Windows上也支持丰富的开发,包括intellisense和调试。即使像Sublime、Emacs、VI等第三方编辑器也很好用,可以使用开源Omnisharp项目获得编辑器智能提示。
2. 微服务
当您构建一个由多个独立的、动态可伸缩的、有状态或无状态微服务组成的微服务定向系统时,您在这里拥有的巨大优势是可以在微服务级别上使用不同的技术/框架/语言。这使您能够在系统中每个微区域中使用最佳的方法和技术,因此,如果您想要构建非常高效和可伸缩的微服务,应该使用.NET Core。如果需要使用任何与.NET Core不兼容的.NET Framework库,则没有问题,您可以使用.NET Framework构建该微服务,在未来可能能够用.NET Core替换它。
您可以使用多种基础设施平台,对于大型和复杂的微服务系统,理想情况下应该使用Azure Service Fabric。但是对于无状态的微服务,您也可以使用其他产品,例如Azure App Service或Azure Functions。
请注意,截至2016年6月,Azure中并非每项技术都支持.NET Core,但随着.NET Core已经发布RTM版本,Azure中的.NET Core支持将大幅增加。
3. 最佳性能和可伸缩性系统
当您的系统需要最佳的性能和可伸缩性,以便在用户数量增加时仍能获得最佳响应性时,这就是.NET Core和ASP.NET Core真正发挥作用的地方。您可以在相同的基础设施/硬件上完成更多工作,从而为最终用户提供更丰富的体验,并降低成本。
摩尔定律单个CPU性能的改进已经不再适用;然而,在您的系统不断增长并且需要更高的可扩展性和性能以满足日益增长的需求时,您需要做更多的事情。您需要更加高效,到处进行优化,并在机器、虚拟机和CPU核集群中实现更好的扩展性。这不仅关乎用户的满意度,还可能在成本/TCO方面产生巨大差异。这就是为什么要追求性能和可伸缩性的原因。
如上所述,如果您可以将系统的小部分隔离为微服务或任何其他松耦合方法,那么会更好,因为您不仅可以独立地发展每个小部分/微服务,并具有更好的长期敏捷性和维护性,而且还可以在微服务级别使用任何其他技术,如果您需要做的不兼容.NET Core。最终,您将能够对其进行重构并将其带入.NET Core。
4. 面向Mac、Linux或Windows的命令行样式开发。
使用.NET Core时,可以选择采用此方法。当然,您也可以使用完整的Visual Studio IDE。但是,如果你是一个想要使用轻量级编辑器和大量使用命令行开发的开发人员,.NET Core专为CLI而设计。它提供了在所有支持的平台上可用的简单命令行工具,使开发人员能够在开发人员、实验室或生产环境机器上进行最小安装来构建和测试应用程序。像Visual Studio Code这样的编辑器使用相同的命令行工具进行开发体验。而像Visual Studio这样的IDE使用相同的CLI工具,但将其隐藏在丰富的IDE体验背后。现在,开发人员可以从CLI到编辑器再到IDE选择他们想要与工具链交互的程度。
5. 每个应用程序级别需要.NET版本并排。
如果您希望能够安装依赖于.NET中不同版本框架的应用程序,则需要使用.NET Core,正如本文档中先前解释的那样,它提供了100%的并排功能。
6. Windows 10 UWP .NET 应用程序。
此外,您可能还想阅读:
这是微软的解释:
.NET Framework是Windows操作系统中分发的“完整”或“传统”的.NET版本。如果您正在构建桌面Windows或UWP应用程序,或者使用旧版ASP.NET 4.6+,请使用此版本。
.NET Core是跨平台的.NET,可在Windows、Mac和Linux上运行。如果您想构建可以在任何平台上运行(包括Docker容器内部)的控制台或Web应用程序,请使用此版本。目前,它不包括UWP/桌面应用程序。
Xamarin用于构建可在iOS、Android或Windows Phone设备上运行的移动应用程序。
Xamarin通常运行在Mono之上,这是一个为了支持跨平台而构建的.NET版本,在Microsoft决定正式采用.NET Core进行跨平台开发之前就已经存在。与Xamarin一样,Unity平台也运行在Mono之上。
您可以在此行中参考- ASP.NET Core (.NET Core)和ASP.NET Core (.NET Framework)之间的区别
Xamarin并没有任何争议。当您想要使用C#构建移动应用程序(iOS、Android和Windows Mobile)时,Xamarin是您唯一的选择。
.NET Framework支持Windows和Web应用程序。今天,您可以使用Windows Forms、WPF和UWP在.NET Framework中构建Windows应用程序。ASP.NET MVC用于在.NET Framework中构建Web应用程序。
.NET Core是新的开源跨平台框架,可用于构建所有操作系统的应用程序,包括Windows、Mac和Linux。 .NET Core仅支持UWP和ASP.NET Core。UWP用于构建以Windows 10为目标的Windows和移动应用程序。ASP.NET Core用于构建基于浏览器的Web应用程序。
如果您需要更多详细信息,请参阅以下链接
https://blogs.msdn.microsoft.com/dotnet/2016/07/15/net-core-roadmap/
https://learn.microsoft.com/en-us/dotnet/articles/standard/choosing-core-framework-server
.NET Standard[蓝色]的实现支持和完全支持.NET Standard的最小可行平台(最新版本:[https://learn.microsoft.com/en-us/dotnet/standard/net-standard#net-implementation-support])
.NET 5将于2020年11月推出,它是所有.NET变体的统一版本,因此不再需要在变体之间选择。
[截至2022年2月]
.NET Core是目前应该使用的.NET版本(更多功能,修复错误等)。
Xamarin是一个平台,提供用C#编写的跨平台移动问题解决方案,因此您无需单独使用Swift进行iOS开发,同样适用于Android。
.Net Framework(最新版本4.8)仅支持Windows平台。这意味着您的桌面应用程序只能在Windows上运行。Web应用程序只能托管在Windows Server / Windows OS上。
.Net Core(从.net core 1、2、2.1、3.1开始,最新版本5)是跨平台的。(Windows,Linux,Mac)。
另一方面,Xamarin支持移动平台。(Android和IOS)。用于开发移动应用程序。
Xamarin用于手机应用程序(包括IOS/Android)。.NET Core用于设计Web应用程序,可以在Apache和IIS上运行。
这就是两个句子的区别。