views:

34

answers:

3

What does this method do, and why is it necessary?

The "go to definition" option leads me to a function containing all comments, here's what it says about its purpose

//Writes the XML declaration with the version "1.0" and the standalone attribute.

what does it mean by "writes the XML declaration"? Is this when it creates the .xml file?

How does it relate to the constructor XmlTextWriter()'s purpose?

+2  A: 

To start with, it belongs to XmlWriter, not really XmlTextWriter. As John Saunders says, the preferred way of creating an XmlWriter is via XmlWriter.Create.

The point of WriteStartDocument is to create this in the output stream:

<?xml version="1.0" ?>

This isn't written when you just create the XmlWriter. It will also potentially specify the encoding. (XML defaults to UTF-8 or UTF-16 if an encoding isn't specified.)

As for whether you need it - XML documents don't have to have an XML declaration, but they "should" according to the spec (i.e. it's best practice).

Jon Skeet
ah, I remember seeing that in my files, I wondered where that came from. thanks!
jwaffe
+1  A: 

The XML declaration is this:

<?xml version="1.0" encoding="utf-8"?>

It should be on top of every XML document because it informs the parser about the encoding used (and the XML version, but that is not important as of today).

Lucero
A: 

So

writer = XmlWriter.Create("file path");

has the same effect as

XmlTextWriter writer = new XmlTextWriter("file path", type);

correct?

Answered, you guys are fast!

Would there be any reason to use Xmltextwriter, or is it just out of date? I'm only asking because I saw a lot of sources using XmlTextWriter and XmlTextReader.

jwaffe
It is quite out of date. Expecially you have to be careful with the `XmlTextReader` since it does load the DTD as well (even though it doesn't use it, it does load and check it for well-formedness, which can cause you trouble for instance with W3C DTDs). I had a web page loading and processing an XHTML document, and it ended up throwing exceptions due to W3C returning 503 errors... see here: http://www.w3.org/blog/systeam/2008/02/08/w3c_s_excessive_dtd_traffic
Lucero