HI I have a xml document like this:
<Students>
<student name="A" class="1"/>
<student name="B"class="2"/>
<student name="c" class="3"/>
</Students>
I want to use XmlReader
to read through this xml and return a list of students as List<student>
.
I know this can be achieved as follows:
List<Student> students = new List<Student>();
XmlReader reader = XmlReader.Create("AppManifest.xml");
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element && reader.Name == "student")
{
students.Add(new Student()
{
Name = reader.GetAttribute("name"),
Class = reader.GetAttribute("Class")
});
}
}
I just want to know if there is any better solution for this?
I am using silverlight 4. The xml structure is static, ie. it will have only one Students
node and all the student node with above said attributes will only be there.
You can use like that:
Absolutely - use LINQ to XML. It's so much simpler:
XmlReader
is a relatively low-level type - I would avoid it unless you really can't afford to slurp the whole of the XML into memory at a time. Even then there are ways of using LINQ to XML in conjunction withXmlReader
if you just want subtrees of the document.Refer to the link below,
http://www.nearinfinity.com/blogs/joe_ferner/performance_linq_to_sql_vs.html
XmlReader
is supported in Silverlight (http://msdn.microsoft.com/en-us/library/cc189001(v=vs.95).aspx)XmlReader
like aSQLDataReader
is basically a non-cached model, so they are performance oriented but you can move only 'Forward' with that.It's alot easier if we're using Linq xml: