• <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>

            風(fēng)一樣的劃過(guò)

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

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

               

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

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


            即,doc對(duì)象釋放時(shí),會(huì)對(duì)所有已經(jīng)連接進(jìn)來(lái)的節(jié)點(diǎn)進(jìn)行釋放,所以不需要手動(dòng)的去釋放所new出來(lái)的東西。
            但是,還需要注意,如果TiXmlDocument對(duì)象也是new出來(lái)的,則需要對(duì)TiXmlDocument對(duì)象執(zhí)行delete,才可以觸發(fā)析構(gòu)函數(shù)被調(diào)用。

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



            Feedback

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

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

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

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

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

            2011-06-18 13:59 by cdy20
            這種方式和qt內(nèi)存管理方式一樣。
            父節(jié)點(diǎn)釋放 同事回檢查子節(jié)點(diǎn) 一起釋放

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

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

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

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

            嗯,當(dāng)然,這樣是件好事,不過(guò),還是要知道它做了什么,這樣用著才踏實(shí)放下。。。

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

            2011-06-20 12:14 by 楊粼波
            RapidXML
            TinyXML
            這兩個(gè)都是比較輕量級(jí)的。其中RapidXML,boost里面有用到。boost/property_tree里面用到了。因?yàn)椋琑apidXML內(nèi)部自建了一個(gè)內(nèi)存池,所以相對(duì)來(lái)說(shuō)要比TinyXML要快。實(shí)驗(yàn)證明確實(shí)是如此的。而且,二者之間使用方法上比較相近。

            # re: TinyXML總結(jié)  回復(fù)  更多評(píng)論   

            2013-07-12 16:57 by 曦花
            終于解答了我的疑問(wèn)
            O(∩_∩)O謝謝你!!!

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            99久久精品国产一区二区蜜芽| 久久久国产打桩机| 日本三级久久网| 热久久视久久精品18| 久久九九久精品国产免费直播| 色欲综合久久躁天天躁蜜桃| 亚洲国产精品久久久久婷婷软件| 久久久99精品成人片中文字幕| 少妇内射兰兰久久| 日本精品一区二区久久久| 99热成人精品热久久669| 香蕉aa三级久久毛片| 国产成人久久激情91| 97精品伊人久久大香线蕉| 91精品国产91热久久久久福利| 久久香蕉国产线看观看精品yw| 国产精品综合久久第一页| 久久国产亚洲高清观看| 久久无码国产专区精品| 精品水蜜桃久久久久久久| 狠狠狠色丁香婷婷综合久久俺| 青草国产精品久久久久久| 亚洲精品无码久久久影院相关影片 | 午夜视频久久久久一区| 777久久精品一区二区三区无码 | 久久99热精品| 久久国产色AV免费观看| 久久精品中文騷妇女内射| 2021国产精品久久精品| 午夜精品久久久久久影视riav| 久久久久久国产精品美女| 国产精品亚洲美女久久久| 国产 亚洲 欧美 另类 久久| 久久99国产精品久久久| 国内精品久久久久久久97牛牛| 看久久久久久a级毛片| 久久亚洲精品人成综合网| 嫩草伊人久久精品少妇AV| 精品久久久久久无码中文字幕一区| 亚洲va久久久噜噜噜久久狠狠| 久久99国产精品久久99小说|