在運行時編輯代碼的 .NET 熱重載的操作方法

今天,我們很高興向你介紹 Visual Studio 2019 中 16.11(預覽版1)中的 .NET 熱重載(通過 .NET 6(預覽版4)中的 dotnet watch 命令行工具)。在這篇文章的其餘部分,我們會介紹什麼是 .NET 熱重載,您如何開始使用這個特性,我們對未來計劃改進的設想,以及目前支持哪種編輯和語言的明確性。

  今天,我們很高興向你介紹 Visual Studio 2019 中 16.11(預覽版1)中的 .NET 熱重載(通過 .NET 6(預覽版4)中的 dotnet watch 命令行工具)。在這篇文章的其餘部分,我們會介紹什麼是 .NET 熱重載,您如何開始使用這個特性,我們對未來計劃改進的設想,以及目前支持哪種編輯和語言的明確性。

什麼是 .NET 熱重載

  使用熱重載,您現在可以在應用程序運行時修改應用程序托管的源代碼,而不需要手動暫停或命中斷點。隻需在應用程序運行時進行受支持的更改,並在我們新的 VisualStudio 體驗中使用“apply code changes”按鈕應用您的編輯。

  熱重載支持已經存在的和即將到來的項目類型,例如 WPF、Windows Forms、.NET MAUI 預覽版、ASP.NET Core、Console 、WinUI 3 等等。這種支持非常廣泛,支持與任何由 .NET Framework 或 CoreCLR 運行時驅動的項目。(This support is very broad with the core experience working with any project that is powered by .NET Framework or CoreCLR runtimes.)

  通過熱重載,我們的目標是讓這種體驗可用,無論您喜歡如何啟動您的應用程序。通過今天的發佈,您現在可以通過完全集成的 Visual Studio 調試器體驗或 dotnet watch 命令行工具使用此體驗,稍後版本將有更多的選項。

開始

  你可以選擇使用 Visual Studio 的最新預覽版,也可以選擇使用 .NET 6 預覽4,介紹如下。

Visual Studio

  在 Visual Studio 中使用調試器時嘗試熱重載:

  • 下載並安裝 Visual Studio 2019 16.11 預覽版1。
  • 打開支持的項目類型,例如 WPF 應用程序。
  • 通過 F5 啟動附加調試器的應用程序(確保在調試器配置中“enable native code debugging”為禁用)。
  • 打開一個 C# 代碼文件,其中有些代碼可以通過正在運行的應用程序的用戶界面重新執行(例如:一個按鈕的邏輯代碼或一個 ViewModel 的 command),或者通過 Timer 間隔觸發一些東西,然後更改代碼。
  • 使用 Visual Studio 中的工具欄新的“應用代碼更改(ALT-F10)按鈕”(Continue 按鈕旁邊)來應用代碼更改。請註意,在使用 Visual Studio 時並不需要保存文件,這給瞭您快速更改代碼並繼續進行調試的靈活性。

  如果您所做的更改得到支持,那麼您的應用程序現在將使用新邏輯在運行時進行修補,並且您應該在下一次通過您的操作或類似計時器的觸發代碼,重新執行更新的代碼時看到應用程序行為的更改。

  您還可以繼續使用其他調試器特性,如斷點、編輯並繼續、XAML 熱重載等。您現在所習慣的一切都應該與 .NET 熱重載完全並行。如果有些東西對你不起作用,請讓我們知道!

CLI

  使用 dotnet watch 從命令行啟動應用時使用熱重載:

  • 安裝 .NET 6 預覽4。
  • 更新你的 ASP.NET Core 項目到 .NET 6。
  • launchSettings.json 中添加 “hotReloadProfile”: “aspnetcore” 屬性。
{
  "profiles": {
    "dotnet": {
      "commandName": "Project",
      "hotReloadProfile": "aspnetcore"
    }
  }
}
  • 使用 dotnet watch 運行項目並查看輸出,它應該顯示啟用瞭熱重載。
  • 對您的應用程序托管代碼進行熱重載支持的代碼更改,並保存文件以應用。

  就像 Visual Studio 的體驗一樣,你的新邏輯現在應該被應用瞭,你應該會在下次更新的代碼被重新執行時看到應用程序行為的變化。

  您也可以通過這種方式修改“blazorwasm”熱重載配置文件,在您的 Blazor WebAssembly 項目中使用上面類似的步驟。你甚至可以在 WindowsForms 或其他由 CoreCLR 支持的項目中嘗試它,隻需手動在 Properties 文件夾下添加一個帶有上面示例內容的名為 launchSettings.json 的文件。

  這一功能仍在開發中,我們正在跟蹤未來的改進,將更容易使用 dotnet watch 來熱重載所有類型的 .NET Core 應用程序,而無需 launchSettings.json 文件,這在當前版本中的還是一個限制。

將在 Visual Studio 2022 和 .NET 6 中的實現最佳

  今天的發佈隻是我們為 .NET 開發人員提供的熱重載的預覽版。在 .NET 6 預覽版和 Visual Studio 2019 中,隻有部分功能可用。該特性的全功能會在 .NET 6(和未來版本的 .NET)以及 Visual Studio 2022 中作為框架和工具集提供最完整功能和最佳經驗。

  為瞭讓你大致瞭解我們計劃在未來的預覽版和最終版本中提供哪些特性,這裡有一些例子:

  • .NET Multi-platform App UI (.NET MAUI):借助 .NET 6 Preview 4,開發人員構建 .NET MAUI 應用程序時,現在可以使用 .NET 熱重載來實現針對 WinUI 3 的項目。在未來的版本中,我們將在 iOS、Android 和 Mac Catalyst 場景中引入 .NET 熱重載支持。
  • Razor Pages:在未來的版本中,將支持熱重載和編輯並繼續 (Edit and Continue,EnC),用於為 .NET 6 或更高版本的網站或 Blazor 應用編輯 Razor。
  • 無需調試器:在 Visual Studio 2022 的未來版本中,我們正在努力添加對使用熱重載而不需要調試器的支持,這意味著開發者將能夠使用 CTRL-F5 啟動他們的應用程序,並且仍然使用熱重載來修補他們正在運行的應用程序。
  • 減少不受支持的更改:在 Visual Studio 2022 和 .NET 6+ 的未來版本中,我們計劃跨多個團隊進行工作,以減少運行時不受支持的編輯的數量。
  • 優化框架以更好地支持熱重載:在.NET 6 中,我們正在研究如何改進某些框架以更好地支持熱重新加載。將包括對 ASP.NET Core, .NET MAUI 和其他框架的調整和優化將使熱重載在更多的情況下更有用。

  以上是我們目前的計劃,請註意,計劃可能會根據客戶的反饋和時間表進行更改。

支持/不支持的更改和語言

  無論你如何使用 .NET 熱重載,請註意,有些更改在運行時是不支持的,會提示你一個粗糙的編輯對話框,並要求你重新啟動應用程序。我們仍致力於該特性和文檔,以詳細說明支持哪些編輯。現在,首先查看現有的編輯並繼續(EnC)列表等效功能。由於熱重載是由 EnC 驅動的,這將為你更好地理解這個新特性提供一個很好的起點。具體請參見:EnC 文檔。

  此外,雖然上面的例子是特別提到 C# 的,但在 Visual Studio 的調試器下運行時,在各種情況下也支持 Visual Basic。F# 目前在 .NET 6 中還不支持,但我們計劃在未來的版本中根據客戶的反饋提供支持。

到此這篇關於在運行時編輯代碼的 .NET 熱重載的操作方法的文章就介紹到這瞭,更多相關.NET 熱重載內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: