ASP.NET Core支持依賴注入軟件設計模式,它允許在不同的組件中注入我們的服務,並且控制服務的初始化。有些服務可以在短時間內初始化,並且只能在某個特別的組件,以及請求中才能用到;而還有一些服務,僅僅只用初始化一次,就可以在整個應用程序中使用。
下面我就講一講ASP.NET Core中服務的生命周期。
Singleton --單例模式
只有一個服務的實例被創建,這個實例,存儲在內存中,可以在整個應用程序中使用。我們可以對一些初始化代價比較大的服務,使用Singleton模式。在代碼中可以這樣:
services.AddSingleton<IProductService, ProductService>();
Scoped --作用域
這種模式下,將會為每一個請求,都創建一個服務的實例。所有同一個請求中的中間件、MVC控制器,等等,都會得到一個相同的服務實例。Entity Framework Context就是一個Scoped服務最好的參考例子。我們可以通過使用AddScoped方法來使用Scoped模式:
services.AddScoped<IProductService, ProductService>();
Transient --短暫的、瞬變的
Transient模式下,服務每次被請求的時候,都會創建一個服務實例,這種模式特別適合輕量級、無狀態的服務。我們可以使用AddTransient方法,來注入服務:
services.AddTransient<IProductService, ProductService>();
如果你想將上面我講到的概念形象化,那么下面的圖標就是你快速參考的一個例子。
對下面圖標的解釋說明:
- Singleton:單例模式下的服務,只有一個服務實例,所有的請求,都是共享着一個服務實例;這種模式下,我們需要並發以及多線程的問題;
- Scoped:為每個請求都創建一個服務的實例,並且在這個請求中,都是可以多次重復使用這個服務實例;每個請求,可以看做一個作用域。request1可以使用服務1的實例,request2可以使用服務2的實例互不干涉;
- Transient:這種模式下,不管是不是同一個請求,每次都會新建一個新的服務實例;這種是最常見的,並且是安全的選擇,如果你擔心多線程的問題的話。