# Saturday, December 06, 2003

Recently I've been reviewing the most efficient way of retrieving values from an XML document in .NET.  As Scott Hansleman mentions, the best way to find this out is to write some code and measure the performance, so I wrote some code that can be downloaded to test the performance of three different approaches:

  • an XmlDocument using XPath queries with SelectSingleNode
  • an XPathDocument with an XPathNavigator
  • using the XmlSerializer to deserialize into a custom class

The results show that the XmlSerializer is fastest once the initial cost of creating temporary assemblies has been overcome.  In situations where the initial performance is most important then an XPathNavigator over an XPathDocument is the fastest.

Approach
Here's more detail about each approach:

Object Type XmlDocument XPathDocument XmlSerializer
Retrieval Method XPath query using XmlDocument.SelectSingleNode XPath queries using an XPathDocument Object properties
Advantages Familiar to many developers. 
XPath queries allow for quick evaluation of complex expressions.
Optimized for XPath and XSLT transformations.
XPath queries allow for quick evaluation of complex expressions.
Likely to become more important in future.
Turns XML into Objects
Disadvantages Slow, requires the whole document to be in memory. Slightly more complex for developers to write than XmlDocument. Requires familiarity with XSD and is more complex to set up. 
Can't match XPath's complex expressions.
Slow due to generation of dynamic assemblies on first use.
Example XmlDocument doc =
   new XmlDocument();
doc.Load(filePath);
XmlNodeList selection =
   doc.SelectNodes(XPath);
result = selection.Item(0).InnerText;
XPathDocument doc =
   new XPathDocument(filePath);
XPathNavigator nav =
   doc.CreateNavigator();
XPathNodeIterator it =
   nav.Select(XPath);
it.MoveNext();
result = it.Current.Value;
XmlTextReader reader =
   new XmlTextReader(filePath);
XmlSerializer ser =
   new XmlSerializer(typeof(message));
message mymsg =
   (message)ser.Deserialize(reader);
result = myMsg.MessageID;

Aaron Skonnard provides some excellent background on the benefits of the XPathDocument over the XmldDocument in his article .NET XML Best Practices: Part I: Choosing an XML API.

For the timing tests I used the code available in the EggHead Cafe article "High-Precision Code Timing in .NET".  Unfortunately the Ticks property of the System.DateTime class is only accurate to around 16ms even though it displays values to 100 nanoseconds.

Results
In this app I take a small XML document with no namespace and retrieve four values from it.  Here are the figures I got when running the console application for the first run and then a repeat run:

Runs XmlDocument XPathDocument/Navigator XML Serialization
1 0.00543 0.00129 0.09020
1 0.00051 0.00035 0.00028

The first time the application is run the XML Serializer has to create temporary dynamic assemblies so it performs the worst, however on subsequent runs within the application it performs the fastest since it can use a cached copy of the temporary assemblies (As Scott found out, these assemblies are not cached in .NET 1.0 if you specify a namespace).  Daniel Cazzulino has some good background on how the XmlSerializer works).  In both the first and the second runs the XPathDocument/XPathNavigator approach is faster than the XmlDocument.

In the sample code I've also presented an ASP.NET web application that can host the same tests.  ASP.NET creates a new AppDomain for each website it hosts and is maintained across requests to the server until it is shut down or recycled. Since the XmlSerializer caches its temporary assemblies based on the AppDomain, using the XmlSerializer in an ASP.NET web application or web service application is actually the fastest technique for retrieving values from an XML document.

In situations where the AppDomain is created per-request then using the XPathDocument/XPathNavigator will be more efficient than an XmlDocument and the XmlSerializier.

Discussion
The XmlSerializer is the fastest way to retrieve values from a small XML file if it is possible to overcome the cost of the creation of the temporary assemblies.  In situations where the first retrieval is the most important, or where more complex XPath queries are used the using an XPathNavigator over an XPathDocument provides better performance than the XmlDocument. 

Thankfully it will be possible with .NET 2.0/Whidbey to use a tool (sgen.exe) to pre-create and compile Serializers.  Doug Purdy covered this in his PDC talk, see Scott's notes.  I believe this will make XmlSerializer the fastest approach to retrieving values from XML, but testing will tell.

Click here to download the sample code.

posted on Saturday, December 06, 2003 7:12:06 PM (GMT Standard Time, UTC+00:00)  #   
Related posts:
Office Server 2007: Can it help me write less code?
Server-side Excel: changing the face of financial apps?
Ray Ozzie: Services Disruption and the need for 'Client Server Service Synergy'
DDD3: Deadline for speaker submissions extended until Monday
DDD III on Sat 3 June: Call for Speakers!
I can see clearly now: NUnitAddin and NCoverBrowser
Tracked by:
"Post massage" (Site map index for adipex realestate) [Trackback]
"agenzia immobiliare padova" (agenzia-immobiliare-padova.bettiemcclain.com) [Trackback]
"design anello fidanzamento" (design-anello-fidanzamento.dinner-tree.com) [Trackback]
"detector metal" (detector-metal.usawaterfronts.com) [Trackback]
"agenzia immobiliare venezia" (agenzia-immobiliare-venezia.bettiemcclain.com) [Trackback]
"internet explorer 7" (internet-explorer-7.kirkstjohns.com) [Trackback]
"assicurazione savona" (assicurazione-savona.california-waterfronts.com) [Trackback]
"id-1192896-a" (id-1192896-a) [Trackback]
"arredamento giardino terrazza" (arredamento-giardino-terrazza.california-waterf... [Trackback]
"zolpidem tartrate" (zolpidem tartrate) [Trackback]
"skelaxin 400mg" (skelaxin 400mg) [Trackback]
"cheap tramadol" (cheap tramadol) [Trackback]
"zocor generic" (zocor generic) [Trackback]
"overnight xanax" (overnight xanax) [Trackback]
"free download linux" (free-download-linux.santacruzcounty-realestate.com) [Trackback]
"oxycontin addiction treatment" (oxycontin addiction treatment) [Trackback]
"long term side effects dilantin" (long term side effects dilantin) [Trackback]
"zocor generic" (zocor generic) [Trackback]
"klonopin addiction" (klonopin addiction) [Trackback]
"effect valium" (effect valium) [Trackback]
"jessica alba nuda" (jessica-alba-nuda.kirkstjohns.com) [Trackback]
"deaths mixing valium and alcohol" (deaths mixing valium and alcohol) [Trackback]
"buy xanax cod" (buy xanax cod) [Trackback]
"phentermine" (phentermine) [Trackback]
"synthroid side effects" (synthroid side effects) [Trackback]
"cheap viagra uk sites" (cheap viagra uk sites) [Trackback]
"ray and peggy pierce condos for sala" (ray-and-peggy-pierce-condos-for-sala.mas... [Trackback]
"tramadol hcl 50 mg tab" (tramadol hcl 50 mg tab) [Trackback]
"side affects of zocor medicine" (side affects of zocor medicine) [Trackback]
"ragazzo londra" (ragazzo-londra.masoncountyrealtyinfo.com) [Trackback]
"lipitor when patent ends and becomes generic?" (lipitor when patent ends and be... [Trackback]
"discounted ambien cr" (discounted ambien cr) [Trackback]
"tramadol in combination with other opioids" (tramadol in combination with other... [Trackback]
"snorting valium" (snorting valium) [Trackback]
http://diazepam.4-pharmacy.com/ [Trackback]
"generic zocor" (generic zocor) [Trackback]
"tramadol quick" (tramadol quick) [Trackback]
"tramadol" (tramadol) [Trackback]
"amoxicillin without prescription" (amoxicillin without prescription) [Trackback]
"amoxicyllin doseage for 9 year old" (amoxicyllin doseage for 9 year old) [Trackback]
"free lortab without a prescription" (free lortab without a prescription) [Trackback]
"essai de ritalin de drogue" (essai de ritalin de drogue) [Trackback]
http://tramadol.specialpharm.com/ [Trackback]
"Valium." (Mixing cocaine and valium.) [Trackback]
"picture of generic oxycontin" (picture of generic oxycontin) [Trackback]
"levitra on line" (levitra on line) [Trackback]
"Lexapro side affects." (Lexapro pour l anxiétã©.) [Trackback]
"buy tramadol online" (buy tramadol online) [Trackback]
"diazepam feline no prescription" (diazepam feline no prescription) [Trackback]
"what are the side effects of vicodin?" (what are the side effects of vicodin?) [Trackback]
"Cialis." (Cialis substitute.) [Trackback]
"buy oxycontin online" (buy oxycontin online) [Trackback]
"adderall" (adderall) [Trackback]
"lexapro d anxiétã© social" (lexapro d anxiétã© social) [Trackback]
"Ambien." (Ambien.) [Trackback]
"lexapro" (lexapro) [Trackback]
"phentermine side effects and dosage" (phentermine side effects and dosage) [Trackback]
"Tramadol 377." (Tramadol withdrawal.) [Trackback]
"zocor information" (zocor information) [Trackback]
"buy codeine online without a prescription" (buy codeine online without a prescr... [Trackback]
"Phentermine side effects." (Phentermine.) [Trackback]
"cheapest phentermine pills" (cheapest phentermine pills) [Trackback]
"valtrex" (valtrex) [Trackback]
"Butalbital." (Butalbital.) [Trackback]
"cheap phentermine ((" (cheap phentermine (() [Trackback]
"Medication butalbital." (Butalbital.) [Trackback]
"fioricet with codeine to buy with no prescription" (fioricet with codeine to bu... [Trackback]
"percocet side effects dosage" (percocet side effects dosage) [Trackback]
"zocor information" (zocor information) [Trackback]
"seroquel drug interaction cholesterol drug" (seroquel drug interaction choleste... [Trackback]
"Oxycodone." (Oxycodone.) [Trackback]
hentai totally spies [Trackback]
brunette thong [Trackback]
toilet slave duties [Trackback]
young russian pussy [Trackback]
naked blonds [Trackback]
lesbien sex [Trackback]
wild secretaries [Trackback]
glass dildo [Trackback]
brunette pussy [Trackback]
japanese upskirt [Trackback]
brunette milfs [Trackback]
free pokemon xxx anime [Trackback]
mmf threesome [Trackback]
college hotties [Trackback]
great cumshots [Trackback]
black and white map of united states [Trackback]
busty rachel [Trackback]
free lesbians licking pussy [Trackback]
brazil scat [Trackback]
nude hunk [Trackback]
scooby doo daphne hentai [Trackback]
"tramadol drug" (tramadol drug) [Trackback]
"Buy ambien." (Buy ambien online.) [Trackback]
"Tramadol cod." (Tramadol 180ct cod only.) [Trackback]
"Bdsm thumbs." (Bdsm thumbs gallery.) [Trackback]
"buy hcl 25mg ephedrine" (buy hcl 25mg ephedrine) [Trackback]
"Anal sex free galleries." (Free anal sex movies.) [Trackback]
"Offerta lavoro campania." (Offerta lavoro campania.) [Trackback]
"annuncio lavoro offerta" (annuncio lavoro offerta) [Trackback]
"Phentermine." (Phentermine.) [Trackback]
"Generic phentermine." (Generic phentermine.) [Trackback]
"Annuncio lavoro offerta." (Annuncio lavoro offerta.) [Trackback]
"mutuo casa" (mutuo casa) [Trackback]
"effects of hydrocodone" (effects of hydrocodone) [Trackback]
"bad side effects of viagra" (bad side effects of viagra) [Trackback]
"Cheap phentermine." (Cheap phentermine.) [Trackback]
"buy soma" (Soma) [Trackback]
"Buy phentermine online with check." (Buy phentermine.) [Trackback]
"Cheap tramadol." (Cheap tramadol.) [Trackback]
"Percocet." (During percocet pregnancy.) [Trackback]
"Vacanza maldive." (Vacanza maldive.) [Trackback]
"Chocolate viagra for women." (Viagra studies women.) [Trackback]
"Buy cialis." (Buy cialis.) [Trackback]
"Side effects of hydrocodone apap." (Effects of hydrocodone.) [Trackback]
"Ricetta veloce." (Ricetta veloce.) [Trackback]
"Metropolitana milano." (Metropolitana milano.) [Trackback]
"Viagra contre des cialis." (Compare viagra levitra cialis.) [Trackback]
"albergo verona" (albergo verona) [Trackback]
"Buy phentermine no rx." (Buy phentermine no rx.) [Trackback]
"Blackjack" (Blackjack) [Trackback]
"Ass rape porn." (Ass rape porn.) [Trackback]
"incontri personali" (incontri personali) [Trackback]
"Cheapest phentermine by check." (Cheapest phentermine.) [Trackback]
"Generic viagra vega." (Generic viagra in canada.) [Trackback]
"Buy Soma" (Buy Soma) [Trackback]
"Rape pics and free." (Free milf rape pics humbnails.) [Trackback]
"Buy Tramadol" (Buy Tramadol) [Trackback]
"Buy Cialis" (Buy Cialis) [Trackback]
"Brutal deepthroat." (Brutal deepthroat movies.) [Trackback]
"Mercatino di natale pescia." (Mercatino di natale pescia.) [Trackback]
"Ashton moore." (Ashton moore.) [Trackback]
"Generic viagra." (Buy generic viagra no prescription.) [Trackback]
"canadian pharmacy viagra" (canadian pharmacy viagra) [Trackback]
"Oral viagra." (Oral viagra.) [Trackback]
"Albergo atene." (Albergo atene.) [Trackback]
"Order tramadol." (Order tramadol overnight.) [Trackback]
"Phentermine 6 pm order." (Phen order phentermine.) [Trackback]
"ricetta cinese" (ricetta cinese) [Trackback]
"Cheapest phentermine." (Cheapest phentermine.) [Trackback]
"acne skin care clinic" (acne treatment skin care) [Trackback]
"free fack rape porn movie" (free fack rape porn movie) [Trackback]
"free brutal tgp" (free brutal tgp) [Trackback]
"Buy cheap phentermine." (Buy cheap phentermine.) [Trackback]
"Buy cheapest phentermine online." (Cheapest phentermine online.) [Trackback]
"Free porn xxx forced or rape uncensored." (Free rape porn.) [Trackback]
"Cheap viagra." (Cheap viagra.) [Trackback]
"online casino" (online casino) [Trackback]
"buy paxil" (paxil) [Trackback]
"Gay rape stories." (Free gay rape thumbnails.) [Trackback]
"buy xanax" (xanax) [Trackback]
"buy diazepam" (buy diazepam) [Trackback]
"xxx rape" (xxx rape) [Trackback]
"monster movie porn teen" (monster movie porn teen) [Trackback]
"california car cheap loan" (california car cheap loan) [Trackback]
"Canadian pharmacy viagra." (Canadian viagra.) [Trackback]
"buy tramadol" (tramadol) [Trackback]
"Brutal blowjobs." (Brutal blowjobs.) [Trackback]
"order viagra" (viagra) [Trackback]
"Urine drug screen and tramadol." (Tramadol drug.) [Trackback]
"buy xanax" (xanax) [Trackback]
"Brutal deepthroat movies." (Brutal deepthroat.) [Trackback]
"Ambien online." (Ambien online.) [Trackback]
"free rape porn" (free rape porn) [Trackback]
"car insurance quote" (car insurance) [Trackback]
"Buy viagra online." (Buy viagra online.) [Trackback]
"buy phentermine" (phentermine) [Trackback]
"online poker" (poker) [Trackback]
"Gay porn rape." (Gay porn rape.) [Trackback]
"order phentermine" (phentermine) [Trackback]
"Buy valium online without a prescription." (Buy valium online without a prescri... [Trackback]
"buy levitra" (levitra) [Trackback]
"free strip poker" (free strip poker) [Trackback]
"absolute poker room reviews" (absolute poker room reviews) [Trackback]
"Homeowner Insurance" (Homeowner Insurance) [Trackback]
"Blackjack" (Blackjack) [Trackback]
"viagra" (viagra) [Trackback]
"Phentermine no prescription." (No prescription phentermine.) [Trackback]
"Homeowners Insurance" (Homeowners Insurance) [Trackback]
"Foto porno gratis." (Porno foto gratis.) [Trackback]
"buy viagra" (viagra) [Trackback]
"Cheap phentrmine 37.5." (Cheap phentrmine 37.5.) [Trackback]
"Homeowners Insurence" (Homeowners Insurence) [Trackback]
"Home Owner Insurence" (Home Owner Insurence) [Trackback]
"Ambien addiction." (Ambien addiction.) [Trackback]
"alessandro bono" (alessandro bono) [Trackback]
"small-business audio guides" (small-business audio guides ) [Trackback]
"Tramadol." (Tramadol.) [Trackback]
"first love flatware" (first love flatware ) [Trackback]
"umanoide" (umanoide) [Trackback]
"adorazione dei magi" (adorazione dei magi) [Trackback]
"Slots Machines" (Slots Machines) [Trackback]
"Hydrocodone bitartrate." (Hydrocodone for sale.) [Trackback]
"driving+directions to excelsior hotel in manhattan" (driving+directions to exce... [Trackback]
"Order xanax online no prescription." (Order safe xanax online.) [Trackback]
"Caribbean Poker" (Caribbean Poker) [Trackback]
"Home Owner Insurance" (Home Owner Insurance) [Trackback]
"Homeowner Insurance" (Homeowner Insurance) [Trackback]
"Cheapest cialis." (Cheapest cialis.) [Trackback]
"buy phentermine" (phentermine) [Trackback]
"180-lortabs on line" (180-lortabs on line) [Trackback]
"buy levitra" (levitra) [Trackback]
"order viagra" (viagra) [Trackback]
"frattini" (frattini) [Trackback]
"buy soma" (soma) [Trackback]