C# : the close method of Xml.Load(file)

后端 未结 3 454
无人共我
无人共我 2021-01-12 10:40

I have written some code that loads an XML document using an XmlDocument object so as to count it\'s nodes. Here is the method:

XmlDocument xml         


        
相关标签:
3条回答
  • 2021-01-12 11:18

    No. The XmlDocument class does not implement IDisposable, so there is no way to force it to release it's resources at will. If you really need to immediately free the memory used by XmlDocument, the only way to do that would be to do the following:

    nodes = null;
    xml = null;
    GC.Collect();
    

    The garbage collector works on a separate thread, so it may still not happen immediately. To force the garbage collection to occur synchronously, before continuing execution of your code, you must also call WaitForPendingFinalizers, as such:

    nodes = null;
    xml = null;
    GC.Collect();
    GC.WaitForPendingFinalizers();
    

    XmlDocument always loads the entire document into memory at once. If you simply want to iterate through the nodes in the document as a stream, only loading a bit at a time, that is what the XmlReader class is for. However, you lose a lot of functionality that way. For instance, there is no way to select nodes via XPath, as you where doing in your example. With XmlReader, you have to write your own logic to determine where in the document you are and whether that matches what you are looking for.

    0 讨论(0)
  • 2021-01-12 11:18

    There is no need to set your object to null. The GC should be able to indicate if the Document isn't being used any further on it's own. This will happen automatically as memory is needed but if you want to clear it immediately call GC.Collect(). See this thread for further discussion.

    0 讨论(0)
  • 2021-01-12 11:31

    If you do not have to Manipulate the XML, just read the XML using XMLReader, that is oneway and the fastest, with less memory intense operation.

    0 讨论(0)
提交回复
热议问题