近日,微軟發佈了.NET Core 2.0,但是開發人員中間仍然存在一些疑惑,就是.NET Core、.NET Standard、Xamarin和.NET Framework有什麼不同。 .NET Framework用於構建桌面應用程式和運行在互聯網信息伺服器(IIS)上的ASP.NET應用程式。它 ...
近日,微軟發佈了.NET Core 2.0,但是開發人員中間仍然存在一些疑惑,就是.NET Core、.NET Standard、Xamarin和.NET Framework有什麼不同。
.NET Framework用於構建桌面應用程式和運行在互聯網信息伺服器(IIS)上的ASP.NET應用程式。它是第一個托管框架。
Xamarin是一個用於構建iOS、Android、macOS和桌面應用程式的框架。
.NET Core
.NET Core是免費、跨平臺的,是托管框架的開源實現。它支持4種類型的應用程式:控制台、ASP.NET Core、雲和通用Windows平臺(UWP)。Windows Forms和Windows Presentation Foundation(WPF)並不包含在.NET Core中。
從技術上講,.NET Core僅支持控制台應用程式。ASP.NET Core和UWP是以.NET Core為基礎構建的應用程式模型。
與.NET Framework不同,.NET Core沒有作為Windows組件考慮。因此,更新是以NutGet包的形式,而不是通過Windows Update。由於.NET Core運行時安裝成了App-Local,而應用程式升級是通過包管理器完成的,所以應用程式可以關聯特定的.NET Core版本以及單獨升級。
.NET Standard
托管框架的每一種實現都有一套自己的基類庫。基類庫(BCL)包含諸如異常處理、字元串、XML、I/O、網路和集合這樣的類。
.NET Standard是一項實現BCL的規範。由於.NET實現需要遵循這項規範,所以應用程式開發人員就不用擔心每一種托管框架實現的BCL不同。
框架類庫(FCL),如WPF、WCF、ASP.NET,不包含在BCL中,因此,也就不包含在.NET Standard中。
.NET Standard與.NET實現之間的關係就和HTML規範與瀏覽器之間的關係一樣。後者是前者的實現。
因此,.NET Framework、Xamarin和.NET Core,每一種托管框架都實現了.NET Standard中的BCL。隨著電腦工業不斷推出新的硬體和操作系統,將來還會出現新的.NET托管框架。該標準讓應用程式開發人員知道,他們可以依賴於一套始終如一的API。
每個.NET版本都對應一個.NET Standard版本。
API一致,將應用程式移植到不同的托管實現以及提供工具都會更簡單。
.NET Standard被定義為一個單獨的NuGet包,因為所有的.NET實現都必須支持它。工具變得簡單了,因為對於特定的版本,它們有一套相同的API。你還可以針對多個.NET實現構建一個庫項目。
你還可以構建特定平臺API的.NET Standard封裝器。
.NET Standard vs 可移植類庫
可移植類庫做的不是同一件事嗎?
可移植類使用多個平臺均都支持的通用API。因此,支持的平臺越多,可用的API就越少,而且,對於特定的平臺組合,很難知道到底支持哪些API。對於一個新平臺,已有的PCL必須重新編譯。PCL還需要微軟針對每個平臺創建一個新的框架實現分支。
由於.NET Standard確定了API,而不是一個實現,所以不需要重新編譯應用程式。任何新發佈的.NET實現都實現了必須的庫。應用程式不需要重新編譯就可以運行在新的硬體平臺或操作系統上。從理論上講,在調用API時可能會捕獲到NotSupportedException異常,但那種情況應該很少見。
小結
.NET Standard是一項API規範,每一個特定的版本,都定義了必須實現的基類庫。
.NET Core是一個托管框架,針對構建控制台、雲、ASP.NET Core和UWP應用程式進行了優化。每一種托管實現(如Xamarin、.NET Core或.NET Framework)都必須遵循.NET Standard實現BCL。
原文鏈接
http://www.infoq.com/cn/news/2017/10/dotnet-core-standard-difference
參考資料
https://github.com/dotnet/standard/blob/master/docs/versions.md