.NET Core、Xamarin、.NET Standard和.NET Framework四者之間的區別介紹

前段時日微軟(Microsoft)正式發佈瞭.NET Core 2.0,在很多開發社區中反響不錯。但還是有一些開發者發出瞭疑問,.NET Core、Xamarin、.NET Standard和.NET Framework之間有哪些不同呢?本文就為大傢簡單描述一下這四者之間的區別。

.NET Core

.NET Core是免費、跨平臺的,是托管框架的開源實現。它支持4種類型的應用程序:控制臺、http://ASP.NET Core、雲和通用Windows平臺(UWP)。Windows Forms和Windows Presentation Foundation(WPF)並不包含在.NET Core中。

從技術上講,.NET Core僅支持控制臺應用程序。http://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、http://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。
  • .NET Framework用於構建桌面應用程序和運行在互聯網信息服務器(IIS)上的http://ASP.NET應用程序。它是第一個托管框架。
  • Xamarin則是一個用於構建iOS、Android、macOS和桌面應用程序的框架。
  • 以上所述是小編給大傢介紹的.NET Core、Xamarin、.NET Standard和.NET Framework四者之間的區別,希望對大傢有所幫助。在此也非常感謝大傢對WalkonNet網站的支持!

推薦閱讀: