ASP.NET在VS2022中使用Dispose釋放資源實例

DisposeFinalize是運行的 .NET 和 .NET Core 應用程序釋放占用的資源的兩種方法。通常,如果應用程序中有非托管資源,應該顯式地釋放這些資源占用的資源。

由於 Finalize的非確定性,以及在性能方面的成本很高,因此 Dispose方法的使用頻率遠高於 Finalize。其實,我們可以在一個實現瞭 IDisposable接口的類型上使用 Dispose方法。

本文中提供的代碼示例均默認運行在 Visual Studio 2022。

使用 VS2022 創建 ASP.NET Core 項目

我們在 Visual Studio 2022 中創建一個 ASP.NET Core 項目。按照以下步驟在 Visual Studio 2022 中創建一個新的 ASP.NET Core Web API 6 項目。

  • 1) 啟動 Visual Studio 2022 IDE。
  • 2) 單擊 “Create new project”。
  • 3) 在 “Create new project” 窗口中,從顯示的模板列表中選擇 “ASP.NET Core Web API”。
  • 4) 點擊下一步。
  • 5) 在 “Configure your new project” 窗口中,指定新項目的名稱和位置。
  • 6) 根據您的偏好,可選擇選中 “Place solution and project in the same directory” 復選框。
  • 7) 點擊下一步。
  • 8) 在接下來顯示的 “Additional Information” 窗口中,從頂部的下拉列表中選擇 .NET 6.0 作為目標框架。將 “Authentication Type” 保留為 “None”(默認)。確保選中 “Use controllers …” 選項。
  • 9) 確保未選中 “Enable Docker,”、“Configure for HTTPS” 和 “Enable Open API Support” 復選框,因為我們不會在此處使用任何這些功能。您也可以選擇取消選中 “Use controllers(取消選中以使用最少的 API)” 復選框,因為我們將創建自己的控制器。
  • 10) 單擊創建。

這將在 Visual Studio 2022 中創建一個新的 ASP.NET Core 6 Web API 項目。我們將在本文的後續部分中使用該項目來說明 Dispose的用法。

1. 創建一個實現 IDisposable 接口的類

我們現在將創建一個實現 IDisposable接口的類,代碼如下:

public class FileManager: IDisposable {
    FileStream fileStream = new FileStream(@"C:\Test.txt",
    FileMode.Append);
    public async Task Write(string text) {
            byte[] buffer = Encoding.Unicode.GetBytes(text);
            int offset = 0;
            try {
                await fileStream.WriteAsync(buffer, offset,
                buffer.Length);
            }
            catch {
                //Write code here to handle exceptions.
            }
    }
    public void Dispose() {
            if (fileStream != null) {
                fileStream.Dispose();
            }
    }
}

FileManager類實現 IDisposable接口並包含兩個方法:WriteDispose。前者用於將文本異步寫入文件,後者用於通過調用 FileStream類的 Dispose方法從內存中刪除 FileStream實例。

下面,我們介紹在 ASP.NET Core 6 中處理 IDisposable對象的四種方法。

2. 使用 “using” 語句處理 IDisposable 對象

處理 IDisposable實例的最簡單方法是使用“using”語句,它會自動調用實例上的 Dispose方法。以下代碼片段說明瞭這一點。

using(FileManager fileManager = new FileManager())
{
        await fileManager.Write("This is a text");
}

3. 在請求結束時處理 IDisposable 對象

在 ASP.NET Core 或 ASP.NET Core MVC 應用程序中工作時,我們可能經常需要在 HTTP 請求結束時處理對象。

HttpResponse.RegisterForDispose方法可用於以這種方式註冊 IDisposable對象以進行處理。它接受實現 IDisposable接口的類的實例,並確保作為參數傳遞給它的 IDisposable對象隨每個請求自動處理。

以下代碼演示瞭如何使用 HttpResponse.RegisterForDispose 方法在每個 HTTP 請求結束時註冊 FileManager類的實例。

public class DefaultController: ControllerBase {
    readonly IDisposable _disposable;
    public DefaultController() {
            _disposable = new FileManager();
    }
}

4. 使用內置的 IoC 容器處理 IDisposable 對象

另一種自動處理 IDisposable對象的方法是使用 ASP.NET Core 中的內置 IoC(控制反轉)容器。您可以利用 TransientScopedSingleton實例來創建服務並將它們添加到內置 IoC 容器中。

IDisposable對象添加到 Startup類的 ConfigureServices方法中的 IoC 容器,以便這些對象隨每個 HTTP 請求自動處理。

5. 使用 IHostApplicationLifetime 事件處理 IDependency 對象

ASP.NET Core 有一個名為 IHostApplicationLifetime的接口,允許您在應用程序啟動或關閉時運行自定義代碼。您可以利用此接口的 Register方法來註冊事件。

Startup類的 Configure方法可以接受以下參數:

  • IApplicationBuilder
  • IHostingEnvironment
  • ILoggerFactory
  • IHostApplicationLifetime

以下代碼演示瞭如何使用 IHostApplicationLifetime接口註冊對象以在應用程序關閉時進行處置。

public void Configure(IApplicationBuilder app, IHostApplicationLifetime hostApplicationLifetime) {
    hostApplicationLifetime.ApplicationStopping.Register(OnShutdown);
}
private void OnShutdown() {
    // 釋放對象的代碼
}

最後,ASP.NET Core 6 中默認不會創建 Startup.cs。我們需要手動創建一個,然後在 Program.cs 文件中編寫以下代碼以指定您將在其中使用的 Startup 類應用程序。

var builder = WebApplication.CreateBuilder(args);
builder.Host.ConfigureWebHostDefaults(webBuilder =>
{
    webBuilder.UseStartup<Startup>();
});
using var app = builder.Build();
app.Run();

與 Finalize 不同,我們顯式使用 Dispose 方法來釋放非托管資源。您應該在實現它的任何對象上顯式調用 Dispose 方法,以釋放該對象可能持有其引用的任何非托管資源。

參考資料:

1. C#教程

2. 編程寶庫

以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: