Loading AI tools
跨平台应用程序开发框架 来自维基百科,自由的百科全书
.NET (3.1版以前稱作.NET Core)是微軟開發的第一個跨平台 (Windows、Mac OSX、Linux)的應用程式開發框架(Application Framework),未來也將會支援FreeBSD與Alpine 平台。.Net Core也是微軟在一開始發展時就開源的軟體平台[4],它經常也會拿來和現有的開源 .NET 平台Mono比較。
此條目需要更新。 (2020年12月10日) |
此條目可参照英語維基百科相應條目来扩充。 (2021年8月16日) |
由於 .NET Core 的開發目標是跨平台的 .NET 平台,因此 .NET Core 會包含 .NET Framework 的類別庫,但與 .NET Framework 不同的是 .NET Core 採用套件化 (Packages) 的管理方式,應用程式只需要取得需要的組件即可,與 .NET Framework 大包式安裝的作法截然不同,同時各套件亦有獨立的版本線 (Version line),不再硬性要求應用程式跟隨主線版本。
.NET Core 專案的主要目標有 [5]:
.NET Core 1.0 于 2016 年 6 月 27 日发布。
2020 年 11 月,微软发布了 .NET 5.0,统一了.NET的各个平台的碎片版本: .NET Framework 4.8, .NET Standard, .NET Core 3.1, Mono, Xamarin等。
2021 年 11 月,微软发布了 .NET 6.0 。
2022 年 11 月,微软发布了 .NET 7.0 。
版本 | 发布日期 | 一同发布的产品 | 最新补丁版本 | 补丁发布日期 | 终止支持[6] |
---|---|---|---|---|---|
.NET Core 1.0 | 2016-06-27[7] | Visual Studio 2015 Update 3 | 1.0.16 | 2019年5月14日 | 2019年6月27日 |
.NET Core 1.1 | 2016-11-16[8] | Visual Studio 2017 Version 15.0 | 1.1.13 | 2019年5月14日 | 2019年6月27日 |
.NET Core 2.0 | 2017-08-14[9] | Visual Studio 2017 Version 15.3 | 2.0.9 | 2018年7月10日 | 2018年10月1日 |
.NET Core 2.1 | 2018-05-30[10] | Visual Studio 2017 Version 15.7 | 2.1.30 (LTS) | 2021年8月19日 | 2021年8月21日 |
.NET Core 2.2 | 2018-12-04[11] | Visual Studio 2019 Version 16.0 | 2.2.8 | 2019年11月19日 | 2019年12月23日 |
.NET Core 3.0 | 2019-09-23[12] | Visual Studio 2019 | 3.0.3 | 2020年2月18日 | 2020年3月3日 |
.NET Core 3.1 | 2019-12-03[13] | Visual Studio 2019 | 3.1.32 (LTS) | 2022年12月13日 | 2022年12月13日 |
.NET 5 | 2020-11-10[14] | Visual Studio 2019 Version 16.8 | 5.0.17 | 2022年5月10日 | 2022年5月10日 |
.NET 6 | 2021-11-08[15] | Visual Studio 2022 Version 17.0 | 6.0.13 (LTS) | 2023年1月10日 | 2024年11月12日 |
.NET 7 | 2022-11-08[16] | Visual Studio 2022 Version 17.4 | 7.0.2 | 2023年1月10日 | 2024年5月14日 |
.NET 8 | 2023-11-14 | 不適用 | 8.0.0 (LTS) | 不適用 | 2026年11月 (預計) |
舊版本 舊版本,仍被支援 当前版本 未来版本 |
.NET Core 是由許多專案所組成,除了基本的類別庫 (Core FX) 之外,也包含採用 RyuJIT 編譯的執行平台 Core CLR、編譯器平台 .NET Compiler Platform、採用 AOT 編譯技術運行最佳化的套件 Core RT (.NET Core Runtime),以及跨平台的 MSIL 編譯器 LLILC (LLVM-based MSIL Compiler) 等專案。
同時,微軟也發展了一個建置技術文件的平台 docfx [17],並運用於 .NET Core 的文件網站。
RyuJIT 是微軟發展的新式即地編譯器 (Just-in-Time Compiler),用以取代現有的 .NET Framework 的 JIT 以及 JIT64 即地編譯器,依據微軟公佈的測試報告,RyuJIT 的效能較前一代的 JIT 提升約 25%,並支援 SIMD (Single Instruction, Multiple Data) 的技術。RyuJIT 同時應用於 .NET Framework 4.6 以及 .NET Core[18]。
Core CLR 移植 .NET Framework 的 CLR 的功能,包含核心程式庫 mscorlib、JIT 編譯器、垃圾收集器 (GC) 以及其他執行 MSIL 所需要的執行期環境。
Core RT 是以 预先编译為主的核心功能,在 .NET Core 內稱為 Core RT,在 UWP 則是稱為 .NET Native。
Core RT 會在建造時期 (非執行期) 在編譯時將 MSIL 轉換成平台原生的機器碼,以獲取較短的啟動時間 (JIT 採用的是執行時期編譯,使得啟動時間拉長),以及記憶體用量減少的優點。Core RT 會在不同的平台使用不同的 AOT 技術:
LLILC (LLVM-based MSIL Compiler,英文發音為 "lilac") 是 .NET Core 在非 Windows 平台的 MSIL 編譯器[19],基於 ECMA-335 (Common Language Infrastructure) 的標準將 MSIL 編譯成原生碼執行,適用於可運行 LLVM 的作業系統,例如 Mac OSX 與 Linux 作業系統。
LLILC 同時支援 JIT (內含 RyuJIT 的實作) 以及 AOT (未來將開始支援) 的編譯方式。
.NET Compiler Platform (專案代碼為 Roslyn) 是將 .NET 平台的編譯架構標準化的平台,它可提供程式管理工具 (如整合開發環境) 相當多的情報,用以發展有助於編寫程式與管理程式結構所需要的功能,例如型別資訊、語法結構、參考連結、語意、編譯器、自動化、錯誤回報等等功能,只要是遵循 CLI 標準的程式語言,都可以利用 .NET Compiler Platform 實作出編譯器,讓程式管理工具能實作如語法提示、語法自動完成、關鍵字高亮等視覺化能力。
.NET Compiler Platform 可同時支援 .NET Framework 4.6 以上版本,.NET Core 也原生支援。
.NET Core 的類別庫採用 NuGet 套件化的架構,應用程式只需要使用 project.json 的 dependencies 區段加入指定套件版本的參考,就能獲得該套件的功能,與以往 .NET Framework 大包式的提供方法完全不同。.NET Core 團隊宣佈已經有 98% 的 .NET Framework 主要類別庫移轉到 .NET Core 平台[20]。
例如下列 project.json 內容,可直接加入 .NET Standard Library (v1.0.0-rc2-23901) 的參考。
{
"version": "1.0.0-*",
"compilationOptions": {
"emitEntryPoint": true
},
"dependencies": {
"NETStandard.Library": "1.0.0-rc2-23901"
},
"frameworks": {
"netstandardapp1.5": {
"imports": "dnxcore50"
}
}
}
.NET Standard Library 是一個總括型的 NuGet Package,其內包含了這些類別庫套件:
其中的 NETStandard.Platform 也是一個總括型套件,包含了下列類別庫套件:
開發人員只需要使用 NETStandard.Library 就能加入所有必要的 .NET Core 類別庫參考,但若不需要這麼多組件,也可以只加入特定的套件即可,不一定都要加入 NETStandard.Library。
對於微軟來說,.NET Core 1.0 (以及早期開發時) 使用 project.json 來處理套件管理與版本相依的問題,是因為很多工具還沒趕上 (例如微軟主力的建置工具 MSBuild),再加上 project.json/xproj 架構並不相容於以 MSBuild 為主的工具鏈 (Toolchain),若是要修改成相容 project.json/xproj 架構的話可能會付出極大成本,因此在 .NET Core 1.0 RC2 發布不久,官方就宣布要將 project.json/xproj 系統移回到以 MSBuild 為主的 csproj [21],例如下列 csproj 的例子即可看到套件參考的內容。
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>netcoreapp1.1</TargetFramework>
</PropertyGroup>
<PropertyGroup>
<PackageTargetFallback>$(PackageTargetFallback);portable-net45+win8+wp8+wpa81;</PackageTargetFallback>
</PropertyGroup>
<PropertyGroup>
<UserSecretsId>aspnet-MyCoolWebApplication-e119bc96-38e9-44ab-b4d3-d54964ade9b1</UserSecretsId>
<DockerComposeProjectPath>..\docker-compose.dcproj</DockerComposeProjectPath>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.ApplicationInsights.AspNetCore" Version="2.0.0" />
<PackageReference Include="Microsoft.AspNetCore" Version="1.1.1" />
<PackageReference Include="Microsoft.AspNetCore.Authentication.Cookies" Version="1.1.1" />
<PackageReference Include="Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore" Version="1.1.1" />
<PackageReference Include="Microsoft.AspNetCore.Identity.EntityFrameworkCore" Version="1.1.1" />
<PackageReference Include="Microsoft.AspNetCore.Mvc" Version="1.1.2" />
<PackageReference Include="Microsoft.AspNetCore.StaticFiles" Version="1.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="1.1.1" PrivateAssets="All" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="1.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer.Design" Version="1.1.1" PrivateAssets="All" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="1.1.0" PrivateAssets="All" />
<PackageReference Include="Microsoft.Extensions.Configuration.UserSecrets" Version="1.1.1" />
<PackageReference Include="Microsoft.Extensions.Logging.Debug" Version="1.1.1" />
<PackageReference Include="Microsoft.VisualStudio.Web.CodeGeneration.Design" Version="1.1.0" PrivateAssets="All" />
<PackageReference Include="Microsoft.VisualStudio.Web.BrowserLink" Version="1.1.0" />
</ItemGroup>
<ItemGroup>
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="1.0.0" />
<DotNetCliToolReference Include="Microsoft.Extensions.SecretManager.Tools" Version="1.0.0" />
<DotNetCliToolReference Include="Microsoft.VisualStudio.Web.CodeGeneration.Tools" Version="1.0.0" />
</ItemGroup>
</Project>
由於 .NET Core 移回了 MSBuild 架構,因此在 Visual Studio 2017 的 .NET Core 工具內,已恢復可直接於 IDE 的 GUI 介面中編修套件參考的功能。
.NET Core 基於跨平台能力,並沒有將與 GUI 高度相關的 API 移植到 .NET Core 內,因此像是 Windows Forms 或是 Windows Presentation Foundation (WPF) 並未移植到 .NET Core。.NET Core 支援主控台應用程式 (Console Application) 以及類別庫 (Class Library) 類型的專案。
不過微軟在其 Universal Windows Platform (UWP) 開發平台使用了 .NET Core[22],並且利用 .NET Native 技術將其效能提升至十分接近原生碼的速度。
ASP.NET Core 則以主控台應用程式驅動其代管環境 Kestrel Server 以支援 ASP.NET Core 程式的執行。
.NET CLI (Command-Line Interface) 指令列工具是 .NET Core 處理建造、執行與編輯工作的主要工具 [23],有幾個主要的動作:
指令 | 說明 |
---|---|
dotnet new | 產生新的基本 .NET 專案內容 (包含 project.json、Program.cs 以及 NuGet.config) |
dotnet restore | 還原所參考的 NuGet 套件 |
dotnet build | 建造 .NET 專案 |
dotnet publish | 產生可發行的 .NET 專案 (包含所屬的 Runtime) |
dotnet run | 編譯與立即執行 .NET 專案 (較適用於 exe 型專案) |
dotnet repl | 啟動互動式的對話 |
dotnet pack | 將專案的產出封裝成 NuGet 套件 |
.NET Core 經常會拿來與其他平台做類比,尤其是它的源頭 .NET Framework 以及另一個相似性質的開源平台 Mono。
據微軟的說明,.NET Core 和 .NET Framework 是子集 (Subset) 與超集 (Superset) 的關係,.NET Core 將會實作出部份的 .NET Framework 功能 (基本上是不含使用者介面的部份),例如 JIT (.NET Core 採用 RyuJIT)、垃圾收集器 (GC) 以及型別 (包含基本型別以及泛型型別等)[24]。未來 .NET Framework 和 .NET Core 也將會是各自發展,但它們也會同時使用彼此的功能,例如 .NET Compiler Platform 與 RyuJIT 等技術。
Mono 是另一個已發展許久的 .NET Framework 跨平台開源版本,基本上並不隸屬微軟官方,而是由社群的力量所主導,自成一個生態系統,也開發出了像Xamarin這樣的跨平台.NET行動應用,.NET Core 與 Mono 未來會是合作的關係,Mono 仍會維持社群力量的維護與發展,而 .NET Core 則會以官方角度來進行發展,兩邊也會一起進行彼此功能上的增進[24]。
.NET Core 與 ASP.NET Core 的關係其實一開始並不是主從關係 [25],ASP.NET Core 的開發初期 (ASP.NET 5) .NET Core 還沒有開始起跑,因此 ASP.NET Core 當時有自己的執行期與工具,一開始稱為 Project K,後來改為 DNX (.NET Execution Environment),DNX 本身就具有可獨立運作的執行能力,不需要依賴 .NET Core 執行,但是這樣會變成 .NET Core 和 ASP.NET Core 雙頭馬車的現象,在 .NET Core 逐漸成熟之後,微軟也決定要將這兩個各自獨立發展的產品線整合在一起,DNX 也將因改用 .NET Core 執行期而終止開發,DNX 的功能將由 .NET Core 以及旗下的 .NET CLI 接替提供,整合後的版本將在 1.0 RC2 時釋出。
.NET 7 支援下列作業系統[26] :
作業系統 | 版本 | 平台 | 組態 |
---|---|---|---|
Windows 用戶端 | Windows 7 SP1, 8.1 | x64, x86 | Windows 7 需要安装扩展安全更新 |
Windows 10 用戶端 | Version 1607+ | x64, x86, Arm64 | |
Windows 11 | Version 22000+ | x64, x86, Arm64 | |
Windows Server | 2012+ | x64, x86 | 全功能版、Server Core |
Windows Nano Server | Version 1809+ | x64 | |
Alpine Linux | 3.15+ | x64, Arm32, Arm64 | |
CentOS | 7+ | x64 | |
Debian | 9+ | x64, Arm32, Arm64 | |
Fedora | 33+ | x64 | |
Linux Mint | 18+ | x64 | 需要 glibc 2.27+ |
OpenSUSE | 15+ | x64 | |
Red Hat Enterprise Linux | 7+ | x64, Arm64 | |
SUSE Linux Enterprise | 12 SP2+ | x64 | |
Ubuntu | 18.04+ | x64, Arm32, Arm64 | |
macOS | 10.15+ | x64, Arm64 | |
Android | API 21+ | x64, Arm32, Arm64 | |
iOS | 10.0+ | x64, Arm32, Arm64 |
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.