關於Dictionary的TryGetValue方法

這個方法時常會用到,而且很有效。TryGetValue:獲取與指定的鍵相關聯的值

比如我們讀取一個xml文件,讓後將其寫入到Dictionary中存儲:

[csharp] view plain copy
  1. private static Dictionary<stringstring> SqlKeyValues = null;  
  2.        /// <summary>  
  3.        /// 必要用戶字段及別名  
  4.        /// </summary>  
  5.        internal static void InitUserFields(XmlDocument xml)  
  6.        {  
  7.            LoadXml(xml);  
  8.   
  9.            XmlNode fields = xml.SelectSingleNode("/configs/users/fields");  
  10.            UserFields = new Dictionary<stringstring>();  
  11.            if (fields.ChildNodes.Count > 0)  
  12.            {  
  13.                foreach (XmlNode n in fields.ChildNodes)  
  14.                {  
  15.                    if (n.NodeType != XmlNodeType.Comment && n.Name.ToLower() == "item")  
  16.                    {  
  17.                        XmlAttribute fieldName = n.Attributes["name"];  
  18.                        UserFields.Add(fieldName.Value, n.InnerXml);  
  19.                    }  
  20.                }  
  21.            }  
  22.        }  

我們可以通過下面方面來獲取對應key的值

[csharp] view plain copy
  1. public static string GetUserField(string fieldName)  
  2.        {  
  3.            string finfo = "";  
  4.            UserFields.TryGetValue(fieldName, out finfo);  
  5.            return finfo;  
  6.        }  
(bool)(UserFields.TryGetValue(fieldName, out finfo))可將其轉爲boo類型,它方便的是避免了判斷key知否存在而引發“給定關鍵字不在字典中。”的錯誤。可以通過下面的測試來更進一步瞭解:

[csharp] view plain copy
  1. Dictionary<stringstring> dic = new Dictionary<stringstring>();  
  2.             dic.Add("aaa""123");  
  3.             dic.Add("bbb""456");  
  4.             dic.Add("ccc""789");  
  5.             dic.Add("ddd""321");  
  6.   
  7.             string outStr = "999";  
  8.             dic.TryGetValue("ttt"out outStr);  
  9.             Response.Write(outStr + "<br />");  
  10.             dic.TryGetValue("bbb"out outStr);  
  11.             Response.Write(outStr + "<br />");  
  12.             //Response.Write(dic["ttt"] + "<br />");  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章