终于知道什么情况下需要实现.NET Core中的IOptions接口
自從接觸 IOptions 之后,一直糾結(jié)這樣的問題:自己定義的 Options 要不要實(shí)現(xiàn)?IOptions 接口。
微軟有的項(xiàng)目中實(shí)現(xiàn)了,比如 Caching?中的?MemoryCacheOptions :
public class MemoryCacheOptions : IOptions<MemoryCacheOptions> {public ISystemClock Clock { get; set; }
? ?public TimeSpan ExpirationScanFrequency { get; set; } = TimeSpan.FromMinutes(1);MemoryCacheOptions IOptions<MemoryCacheOptions>.Value{ get { return this; }} }
有的項(xiàng)目中就沒有實(shí)現(xiàn),比如?Session 中的?SessionOptions :
public class SessionOptions{public string CookieName { get; set; } = SessionDefaults.CookieName;
public string CookieDomain { get; set; }
public string CookiePath { get; set; } = SessionDefaults.CookiePath;
public bool CookieHttpOnly { get; set; } = true;
public CookieSecurePolicy CookieSecure { get; set; } = CookieSecurePolicy.None;
public TimeSpan IdleTimeout { get; set; } = TimeSpan.FromMinutes(20);}
但自己一直沒發(fā)現(xiàn)實(shí)現(xiàn) IOptions 究竟有什么用處,于是之前的代碼就都沒實(shí)現(xiàn),比如之前一篇博文中的?TopClientOptions 。
今天在使用 EnyimMemcachedCore?,需要手動(dòng) new MemcachedClientOptions 給?MemcachedClientConfiguration 的構(gòu)造函數(shù)傳參時(shí),終于明白了實(shí)現(xiàn)?IOptions 的真正用處。
public class MemcachedClientConfiguration : IMemcachedClientConfiguration { public MemcachedClientConfiguration(ILogger<MemcachedClient> logger,IOptions<MemcachedClientOptions> optionsAccessor){} }如果?MemcachedClientOptions 不實(shí)現(xiàn)?IOptions<MemcachedClientOptions> 接口,就根本無法將?MemcachedClientOptions 的實(shí)例傳遞給?MemcachedClientConfiguration 的構(gòu)造函數(shù)。
所以,如果完全使用依賴注入,不會(huì)出現(xiàn)手動(dòng) new 的情況,可以不用實(shí)現(xiàn)?IOptions 。否則,必須要實(shí)現(xiàn)。保險(xiǎn)起見,還是實(shí)現(xiàn)一下為好。
public class MemcachedClientOptions : IOptions<MemcachedClientOptions> { //..public MemcachedClientOptions Value => this; }原文地址:http://www.cnblogs.com/dudu/p/6882110.html
.NET社區(qū)新聞,深度好文,微信中搜索dotNET跨平臺(tái)或掃描二維碼關(guān)注
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的终于知道什么情况下需要实现.NET Core中的IOptions接口的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: Vue 2017 现状与展望 | 视频+
- 下一篇: 基于ZKWeb + Angular 4.
