• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            風一樣的劃過

            繼續那未完成的征途。。。
            posts - 3, comments - 7, trackbacks - 0, articles - 0

            TinyXML總結

            Posted on 2011-06-17 13:03 昨日不在,今日不怠 閱讀(5767) 評論(7)  編輯 收藏 引用

                
            TinyXMLDocument的撤銷問題
                   自己寫了一個xml讀取寫入的程序,但在最初沒怎么在意,在調試過程中程序總是崩潰,后來發現有個指針調用為空(C++中的陷阱就在于此)。另一方面,卻發現使用TinyXML過程中使用了好多new來創建節點。C++不像java和C#,要事必躬親,自己管理內存。new創建的對象都保存在堆上,必須手動delete掉。可我也沒做處理,開始迷惑了。
                 找了半天,最后還是發現的端倪:
                  對于一個TinyXMLDocument對象,在析構時,會將其子節點都釋放掉,它的子節點都是new出來的,也必須delete掉。但TinyXML的析構函數是空的,什么也沒寫,不要忘了,TinyXMLDocument是從TinyXMLNode繼承而來,在TinyXMLNode的析構函數中,卻清楚的寫著:

               

            TiXmlNode::~TiXmlNode()
            {
                TiXmlNode* node = firstChild;
                TiXmlNode* temp = 0;

                while ( node )
                {
                    temp = node;
                    node = node->next;
                    delete temp;
                } 
            }


            即,doc對象釋放時,會對所有已經連接進來的節點進行釋放,所以不需要手動的去釋放所new出來的東西。
            但是,還需要注意,如果TiXmlDocument對象也是new出來的,則需要對TiXmlDocument對象執行delete,才可以觸發析構函數被調用。

            參考
                  http://blog.csdn.net/zhoubl668/archive/2008/12/29/3635320.aspx
                  http://m.shnenglu.com/zhaoyg/archive/2010/03/29/110862.html  
                 http://hi.baidu.com/hpagent/blog/item/7c3cf8fe17c54790b801a066.html 



            Feedback

            # re: TinyXML總結  回復  更多評論   

            2011-06-17 21:02 by xiao_liang
            CMarkup挺好用

            # re: TinyXML總結  回復  更多評論   

            2011-06-18 12:20 by right
            以前也用tiny,現在都用RapidXML了

            # re: TinyXML總結  回復  更多評論   

            2011-06-18 13:59 by cdy20
            這種方式和qt內存管理方式一樣。
            父節點釋放 同事回檢查子節點 一起釋放

            # re: TinyXML總結  回復  更多評論   

            2011-06-18 23:16 by 昨日不在,今日不怠
            @right
            評價比tinyxml高啊,可以試試。謝謝交流!

            # re: TinyXML總結  回復  更多評論   

            2011-06-18 23:19 by 昨日不在,今日不怠
            @cdy20

            嗯,當然,這樣是件好事,不過,還是要知道它做了什么,這樣用著才踏實放下。。。

            # re: TinyXML總結  回復  更多評論   

            2011-06-20 12:14 by 楊粼波
            RapidXML
            TinyXML
            這兩個都是比較輕量級的。其中RapidXML,boost里面有用到。boost/property_tree里面用到了。因為,RapidXML內部自建了一個內存池,所以相對來說要比TinyXML要快。實驗證明確實是如此的。而且,二者之間使用方法上比較相近。

            # re: TinyXML總結  回復  更多評論   

            2013-07-12 16:57 by 曦花
            終于解答了我的疑問
            O(∩_∩)O謝謝你?。?!
            热re99久久精品国99热| 一级做a爰片久久毛片毛片| 国产成人无码精品久久久性色| 亚洲人成电影网站久久| 亚洲国产一成久久精品国产成人综合| 伊人色综合久久天天人守人婷| 久久精品九九亚洲精品| 伊人热人久久中文字幕| 思思久久99热免费精品6| 久久婷婷国产综合精品| 久久久久18| 久久偷看各类wc女厕嘘嘘| 久久精品国产第一区二区| 亚洲AV无码1区2区久久| 久久国产成人午夜AV影院| 蜜臀久久99精品久久久久久小说 | 国内精品久久久久久久97牛牛| 久久精品国产只有精品66| 尹人香蕉久久99天天拍| 亚洲欧洲久久av| 漂亮人妻被中出中文字幕久久| 欧美喷潮久久久XXXXx| 无码人妻久久一区二区三区蜜桃| 色综合久久综合中文综合网| 欧洲性大片xxxxx久久久| 久久精品国产91久久综合麻豆自制 | 欧美亚洲另类久久综合| 国产亚洲精久久久久久无码77777| 日韩亚洲欧美久久久www综合网 | 久久这里只有精品18| 欧美亚洲国产精品久久久久| 99久久夜色精品国产网站| 久久久国产精品亚洲一区| 亚洲AV无码一区东京热久久| 国内精品伊人久久久久妇| 午夜精品久久久久成人| 久久99精品久久久久久齐齐| 久久久久久噜噜精品免费直播| 久久精品国产亚洲Aⅴ香蕉 | 东方aⅴ免费观看久久av| 久久久久久久女国产乱让韩|