日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
XML數(shù)據(jù)讀取方式性能比較

幾個月來,疑被SOA,一直在和xml操作打交道,SQL差不多又忘光了?,F(xiàn)在已經(jīng)知道,至少有四種常用人XML數(shù)據(jù)操作方式(好像java差不多),不過還沒有實際比較過這些方式各有哪些特點或優(yōu)劣。正好看到網(wǎng)上也沒有這方面的實驗,偶來總結一下。

測試開始先讀取XML源,用一個比較大的rss文件鏈接,復制到項目bin/debug目錄下。

 
 
 
  1. Stream xmlStream = new MemoryStream(File.ReadAllBytes(path)); 
  

一、XmlDocument 方式

代碼

 
 
 
  1. static IList testXmlDocument()   
  2. {   
  3. var doc = new XmlDocument();   
  4. doc.Load(xmlStream);   
  5. var nodeList = doc.DocumentElement.ChildNodes;   
  6. var lstChannel = new List(nodeList.Count );   
  7. foreach (XmlNode node in nodeList)   
  8. {   
  9. var channel = new 
  10. {  
  11. Title = node.SelectSingleNode("title").InnerText,  
  12. Link = node.SelectSingleNode("link").InnerText,  
  13. Description = node.SelectSingleNode("description").InnerText,  
  14. Content = node.SelectSingleNode("content").InnerText,  
  15. PubDate = node.SelectSingleNode("pubDate").InnerText,  
  16. Author = node.SelectSingleNode("author").InnerText,  
  17. Category = node.SelectSingleNode("category").InnerText  
  18. };  
  19. lstChannel.Add(channel);  
  20. }   
  21. return lstChannel;  
  22. }  
  23. 二、XPathNavigator 方式

    代碼

     
     
     
    1. static IList testXmlNavigator()   
    2. {   
    3. var doc = new XmlDocument();   
    4. doc.Load(xmlStream);    
    5. var nav = doc.CreateNavigator();   
    6. nav.MoveToRoot();   
    7. var nodeList = nav.Select("/channel/item");   
    8. var lstChannel = new List(nodeList.Count);   
    9. foreach (XPathNavigator node in nodeList)  
    10. {  
    11. var channel = new 
    12. {  
    13. Title = node.SelectSingleNode("title").Value,  
    14. Link = node.SelectSingleNode("link").Value,  
    15. Description = node.SelectSingleNode("description").Value,  
    16. Content = node.SelectSingleNode("content").Value,  
    17. PubDate = node.SelectSingleNode("pubDate").Value,  
    18. Author = node.SelectSingleNode("author").Value,  
    19. Category = node.SelectSingleNode("category").Value  
    20. };  
    21. lstChannel.Add(channel);  
    22. }  
    23. return lstChannel;  
    24. }  
    25. 三、XmlTextReader 方式

      代碼

       
       
       
      1. static List testXmlReader()  
      2. {   
      3. var lstChannel = new List();   
      4. var reader = XmlReader.Create(xmlStream);   
      5. while (reader.Read())   
      6.  {   
      7. if (reader.Name == "item" && reader.NodeType == XmlNodeType.Element)   
      8.  {  var channel = new Channel();  
      9. lstChannel.Add(channel);  
      10.  while (reader.Read())  
      11.  {  
      12.  if (reader.Name == "item") break;  
      13.  if (reader.NodeType != XmlNodeType.Element) continue;  
      14.  switch (reader.Name)  
      15.  {  
      16.  case "title":  
      17.  channel.Title = reader.ReadString();  
      18. break;  
      19. case "link":  
      20. channel.Link = reader.ReadString();  
      21. break;  
      22.  case "description":  
      23. channel.Description = reader.ReadString();  
      24. break;  
      25. case "content":  
      26. channel.Content = reader.ReadString();  
      27. break;  
      28.  case "pubDate":  
      29.  channel.PubDate = reader.ReadString();  
      30.  break;  
      31.  case "author":  
      32. channel.Author = reader.ReadString();  
      33.  break;  
      34. case "category":  
      35. channel.Category = reader.ReadString();  
      36.  break;  
      37. default:  
      38. break;  
      39. }}}}  
      40. return lstChannel;  
      41. }  

      四、Linq to XML 方式

      代碼

       
       
       
      1. static IList testXmlLinq()  
      2. {   
      3. var xd = XDocument.Load(xmlStream);   
      4. var list = from node in xd.Elements("channel").Descendants("item")   
      5. select new   
      6. {   
      7. Title = node.Element("title").Value,   
      8. Link = node.Element("link").Value,   
      9. Description = node.Element("description").Value,  
      10. Content = node.Element("content").Value,  
      11. PubDate = node.Element("pubDate").Value,  
      12. Author = node.Element("author").Value,  
      13. Category = node.Element("category").Value  
      14. };  
      15. return list.ToList();  

      測試結果:

      XmlDocment 47ms

      XPathNavigator 42ms

      XmlTextReader 23ms

      Xml Linq 28ms

      小結一下自己的認識,XmlDocument的操作基本按W3C的DOM操作方式,不過要將全部節(jié)點解析成對象加載到內(nèi)存中,往往造成很大浪費。所以微軟自己的編程規(guī)范也不推薦用它。這里由于讀取了所有節(jié)點,可能因此性能和Navigator方式相差不大。在三種隨機讀取方式中,Xml Linq性能最高,只是方法名有點別扭。XmlTextReader方式是所謂的SAX,只讀向前,無疑性能最高,不過實現(xiàn)上麻煩了不少,要比較精確的控制訪問邏輯,也無法用匿名類存儲數(shù)據(jù)。

      .Net 3.5發(fā)布Xml Linq可以很好地取代前兩種方式,通常情況下,最好用它。只有個別場合,如果對性能要求極高,或者讀取Xml數(shù)據(jù)量太大不能一下子下載或讀取到內(nèi)存中,那就只好痛苦委身于XmlTextReader了。

      【編輯推薦】

      1. Android學習筆記:Layout.xml屬性
      2. Ajax和Web服務數(shù)據(jù)格式:XML SOAP HTML
      3. SQL Server數(shù)據(jù)庫與XML標識語言的集成
      4. XML中的層疊樣式

      文章名稱:XML數(shù)據(jù)讀取方式性能比較
      轉載源于:http://m.5511xx.com/article/djshgsg.html