亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

挖一挖C#中那些我們不常用的東西之系列(1)——ToDictionary,ToLookup

2019-11-14 16:46:58
字體:
來源:轉載
供稿:網友

  這個系列我們看看C#中有哪些我們知道,但是又不知道怎么用,又或者懶得去了解的東西,比如這篇我們要介紹的toDictionary

和ToLookup。

  從圖中我們看到有四個ToXXX的方法,其中ToArray和ToList,我想大家用的是非常非常多,但是ToDictionary和ToLookup

不見得有多少人用了,但不能否認的是這些方法確實很有用。

     不多廢話了,直接如主題,我們有這樣的一個實體,包含:票號,訂單號,備注。

    class Ticket    {        /// <summary>        /// 票號        /// </summary>        public string TicketNo { get; set; }        /// <summary>        /// 訂單號        /// </summary>        public int OrderID { get; set; }        /// <summary>        /// 備注        /// </summary>        public string Description { get; set; }    }


好了,我們看看需求,票號和訂單號是一對多的關系,也就是說一個訂單號可能包含幾個票號,每個票號都有自己對應的狀態,

比如票號有 “改簽”,"未使用",“成交”,"退票" 等等,下面我們灌一批數據進去。

        public static List<Ticket> GetList()        {            return new List<Ticket>()            {                 new Ticket(){ TicketNo="999-12311",OrderID=79121281,Description="改簽"},                 new Ticket(){ TicketNo="999-24572",OrderID=29321289,Description="退票"},                 new Ticket(){ TicketNo="999-68904",OrderID=19321289,Description="成交"},                 new Ticket(){ TicketNo="999-24172",OrderID=64321212,Description="未使用"},                 new Ticket(){ TicketNo="999-24579",OrderID=19321289,Description="退票"},                 new Ticket(){ TicketNo="999-21522",OrderID=79121281,Description="未使用"},                 new Ticket(){ TicketNo="999-24902",OrderID=79121281,Description="退票"},                 new Ticket(){ TicketNo="999-04571",OrderID=29321289,Description="改簽"},                 new Ticket(){ TicketNo="999-23572",OrderID=96576289,Description="改簽"},                 new Ticket(){ TicketNo="999-24971",OrderID=99321289,Description="成交"}            };        }


舉個例子: 我需要統計各個訂單號中的票號情況。

  

      很明顯,這是一個分組排序的問題,可能你馬上就想起了groupby來實現,當然groupby是可以實現的,不過groupby不能算是一種數據

結構,不能帶有索引,沒有字典那樣容易輸出和操作。

 

方案一: 采用普通的foreach循環。

             一般情況下,可能有一部分人都采用這種原始的方法,將list數據通過foreach循環放到dictionary中,就是代碼寫的多一些,也算

是最靈活的。

 

            Dictionary<int, Ticket> dic = new Dictionary<int, Ticket>();            foreach (var item in ticketlist)            {                if (!dic.ContainsKey(item.OrderID))                {                    dic.Add(item.OrderID, item);                }                else                {                    dic[item.OrderID] = item;                }            }

 

方案二:使用ToDictionary
  

  

     

       從圖中我們可以看到,發生悲劇的異常了,我們知道dictionary中key是不能重復的,然而ToDictionary中并沒有給我們做

key的重復值判斷,那也就側面說明ToDictionary在kv中只能是 “一對一”的關系,也就是v中永遠只會有一條記錄,顯然這不是

我需要的,在了解ToDictionary原理后,該方案失敗。

 

方案三: 使用ToLookup

  

  也許微軟知道客戶有這么個需求,就采用了一個ToDictionary的加強版,你也可以認為是一種新的字典數據結構,它就避免了這

種“一對一”的關系,采用“一對多”的實現。

            var dic = ticketlist.ToLookup(i => i.OrderID);            foreach (var item in dic)            {                Console.WriteLine("訂單號:" + item.Key);                foreach (var item1 in item)                {                    Console.WriteLine("/t/t" + item1.TicketNo + "  " + item1.Description);                }            }

 

 而且ToLookup和字典一樣,是帶有索引形式,這個groupby就不具備了,當然Tolookup還有一個強大的功能,就是使用

Func<TSource, TElement> elementSelector來對現在的v元素進行轉換來避免我剛才  Console.WriteLine("/t/t" + item1.

TicketNo + "  " + item1.Description);語句

 

好了,大概就這樣了,趕緊停筆,不說了。。。妹子催著要去顧村公園。o(∩_∩)o

 

 

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
992tv成人免费视频| 国产日本欧美一区二区三区在线| 国产免费一区二区三区在线能观看| 久久久爽爽爽美女图片| 日韩av综合中文字幕| 欧美丰满老妇厨房牲生活| 亚洲欧洲中文天堂| 岛国av一区二区三区| 久久精品美女视频网站| 色偷偷偷综合中文字幕;dd| 国产一区二区三区精品久久久| 欧美电影免费播放| 国产亚洲美女久久| 国内精品久久久久伊人av| 亚洲精品少妇网址| 91精品在线国产| 最近2019免费中文字幕视频三| 亚洲自拍偷拍色图| 综合久久五月天| 亚洲的天堂在线中文字幕| 97视频在线看| 日韩av第一页| 国产精品看片资源| 国产亚洲精品美女久久久久| 亚洲аv电影天堂网| 97精品欧美一区二区三区| 国产成人一区二区三区| 欧美电影免费看| 久久午夜a级毛片| 国产精品精品视频一区二区三区| 亚洲japanese制服美女| 国产福利成人在线| 欧美裸体xxxx极品少妇| 日本亚洲欧美成人| 一区二区三区视频免费在线观看| 麻豆精品精华液| 色老头一区二区三区在线观看| 黑人极品videos精品欧美裸| 日韩激情视频在线播放| 亚洲国产成人精品女人久久久| 欧美视频专区一二在线观看| 九九热精品视频国产| 91chinesevideo永久地址| 欧美精品一本久久男人的天堂| 欧美激情精品在线| 国产自产女人91一区在线观看| 国内精品久久久久久久| 欧美专区福利在线| 亚洲乱码一区二区| 国产日韩中文字幕在线| 人体精品一二三区| 精品久久久久久久久国产字幕| 久久久久久亚洲精品中文字幕| 久久综合免费视频影院| 国产+成+人+亚洲欧洲| 国产亚洲精品高潮| 91av网站在线播放| 精品在线观看国产| 91免费国产网站| 北条麻妃99精品青青久久| 最近2019免费中文字幕视频三| 国产午夜精品视频免费不卡69堂| 国产精品国产三级国产专播精品人| 国内精品国产三级国产在线专| 国产精品福利在线观看| 亚洲欧美日韩中文视频| 国产精品美女免费看| 欧美日韩亚洲一区二区三区| 欧美精品在线免费观看| 亚洲丁香婷深爱综合| 亚洲综合在线中文字幕| 亚洲精品动漫久久久久| 国产精品一区二区久久| 欧日韩在线观看| 午夜精品久久久久久久99热| 狠狠做深爱婷婷久久综合一区| 欧美精品中文字幕一区| 日韩女在线观看| 国产99久久精品一区二区永久免费| 欧美日韩国产一区二区三区| 亚洲男女性事视频| 欧美精品在线免费| 国产精自产拍久久久久久蜜| 欧美wwwwww| 午夜精品久久久久久久久久久久久| 精品国产一区二区三区四区在线观看| 日本精品久久久久久久| 国产精品主播视频| 国产视频在线一区二区| 91亚洲精品久久久| 日韩免费在线免费观看| 在线观看国产精品日韩av| 97免费在线视频| 亚洲精品久久久久中文字幕欢迎你| 国产精品久久久久久五月尺| 国产日韩欧美在线观看| 日本高清+成人网在线观看| 亚洲欧美综合区自拍另类| 不卡av在线网站| 国产福利成人在线| 日韩精品视频在线免费观看| 懂色av中文一区二区三区天美| 国产日韩中文字幕在线| 浅井舞香一区二区| 69精品小视频| 欧美精品少妇videofree| 欧美最猛性xxxxx(亚洲精品)| 日韩av在线免播放器| 欧美一级片一区| 国内精品久久久久影院 日本资源| 欧美日韩国产一区二区三区| 亚洲欧美日韩中文视频| 欧美激情va永久在线播放| 欧美激情中文字幕乱码免费| 日韩成人小视频| 久久久久日韩精品久久久男男| 亚洲最新av在线| 国产精品大片wwwwww| 日韩电影在线观看免费| 中文字幕日韩精品有码视频| 成人高h视频在线| 亚洲国产精品久久久久秋霞蜜臀| 色婷婷成人综合| 欧美美女18p| 亚洲欧美日韩一区二区在线| 性色av一区二区三区免费| 亚洲成人三级在线| 国产精品海角社区在线观看| 亚洲国产成人爱av在线播放| 26uuu亚洲伊人春色| 日韩欧美亚洲一二三区| 91av国产在线| 欧美激情在线狂野欧美精品| 国产精品影片在线观看| 美女国内精品自产拍在线播放| 国产亚洲精品综合一区91| 视频在线一区二区| 国产一区二区美女视频| 午夜精品久久久99热福利| 欧美成aaa人片在线观看蜜臀| 欧美一级免费看| 亚洲国产精品热久久| 红桃视频成人在线观看| 国产精品扒开腿做| 日韩电影中文 亚洲精品乱码| 深夜福利日韩在线看| 日韩av网站导航| 久久在线视频在线| 亚洲欧美激情在线视频| 亚洲级视频在线观看免费1级| 国产精品69精品一区二区三区| 欧美尤物巨大精品爽| 日韩欧美亚洲范冰冰与中字| 日韩亚洲精品电影| 国产乱人伦真实精品视频| 午夜精品久久久久久久男人的天堂| 一区二区福利视频| 亚洲天堂av电影| 亚洲一区二区国产| 国产精品99蜜臀久久不卡二区| 亚洲最大福利网站| 日本亚洲欧洲色| 最新国产成人av网站网址麻豆| 日韩av电影在线免费播放|