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

            力為的技術(shù)博客

            聯(lián)系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

            一、需求:

            現(xiàn)在需要用一個(gè)容器存放若干對(duì)象的指針(AObject*),對(duì)象指針在容器中的順序按照對(duì)象某個(gè)屬性(pObject->GetValue();)從低到高排序。

            二、"解決"方法:

            1. 使用std::set
            set中的元素是按照一定的順序的存放的(根據(jù)元素的大小)。通過(guò)制定set的第二個(gè)模板參數(shù)就可以讓它按我們的要求順序排放。

            先寫一個(gè)函數(shù)對(duì)象:

            // object compare functor
            class CompareObject
            {
               
            bool operator() (AObject* lhv, AObject* rhv)
              
            {
                  
            return lhv->GetValue() < rhv->GetValue();
              }

            }


            // decleare the object container;
            typedef std::set<AObject*, CompareObject> AObjectContainer;
               AObjectContainer setContainer;


            這種方法有啥問(wèn)題?
            (見(jiàn)文后)

            2. 使用std::list
            list中的元素默認(rèn)不會(huì)排序,需要我們“手動(dòng)”排序。
            用list這樣聲明:

            typedef std::list<AObject*> AObjectContainer;
               AObjectContainer listContainer;


            添加完元素后,再排序:

            (1)使用std::sort?
            可注意了,std::list貌似不支持用std::sort進(jìn)行用戶自定義排序,反正我是沒(méi)有試成功(有興趣的同學(xué)可以解釋一下)。假如這樣寫是錯(cuò)誤的:

            std::sort(listContainer.begin(), listContainer.end(), CompareObject());


            (2)使用list.sort()

            listContainer.sort(CompareObject());


            三、分析

            方法1存在非常嚴(yán)重的問(wèn)題——內(nèi)存泄漏。
            set中的元素是按序排列(此處是按object.GetValue()的大小排序,我們把這個(gè)值也叫key吧),注意的是set中不存在key值相等的元素。假如要插入的元素在set中已經(jīng)存在會(huì)發(fā)生什么呢?是用新的元素替換原來(lái)的元素還是保留原來(lái)的元素呢?(有興趣有時(shí)間的同學(xué)幫忙做個(gè)實(shí)驗(yàn)吧)但有一點(diǎn)可以肯定,有一個(gè)被遺失了。如果set中存放的是對(duì)象,還沒(méi)啥問(wèn)題。但現(xiàn)在set中存放的是指針,于是內(nèi)存便泄漏了。
            posted on 2009-03-10 22:47 力為 閱讀(2811) 評(píng)論(9)  編輯 收藏 引用 所屬分類: Tools

            評(píng)論

            # re: STL容器誤用一則 2009-03-11 09:12 路人丁
            "但現(xiàn)在set中存放的是指針,于是內(nèi)存便泄漏了。" --- 只能說(shuō)明你設(shè)計(jì)錯(cuò)誤,既然你存指針,那么就應(yīng)該自己保證釋放;

            “假如要插入的元素在set中已經(jīng)存在會(huì)發(fā)生什么呢?是用新的元素替換原來(lái)的元素還是保留原來(lái)的元素呢?” --- 容器選擇錯(cuò)誤,如果你想保存相等值,那么應(yīng)當(dāng)用multiset,而不是set。  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則 2009-03-11 09:18 力為
            @路人丁
            兄弟說(shuō)的對(duì)。標(biāo)題說(shuō)的就是誤用,肯定是設(shè)計(jì)的問(wèn)題:),也就是說(shuō)此處用set是肯定有問(wèn)題的。  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則 2009-03-11 09:22 Kevin Lynx
            存檔的指針指向的內(nèi)存是由你自己來(lái)維護(hù)的,不是set來(lái)維護(hù),所有有內(nèi)存泄露,也是你自己的錯(cuò)誤。

            std::sort不能對(duì)std::list進(jìn)行排序,那是因?yàn)閟td::sort只能對(duì)random-access iterator進(jìn)行操作,std::list::iterator不是random-access的。所以std::list才自己提供了sort函數(shù)。

            詳細(xì)參看std::sort文檔  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則 2009-03-11 09:25 力為
            @Kevin Lynx
            此處假定在最后會(huì)把set中所有的指針刪除。  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則 2009-03-11 12:10 yindf
            容器里存放對(duì)象指針,一般建議用smart_ptr.
            原生指針遇到多態(tài),就哭了。  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則[未登錄](méi) 2009-03-11 12:16 apan
            關(guān)于STL中的sort函數(shù),看看這篇文章
            http://www.stlchina.org/twiki/bin/view.pl/Main/STLSortAlgorithms  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則[未登錄](méi) 2009-03-11 22:09 koobin
            “假如要插入的元素在set中已經(jīng)存在會(huì)發(fā)生什么呢?是用新的元素替換原來(lái)的元素還是保留原來(lái)的元素呢?”
            你的set中存放的是指針,如果已經(jīng)存在,那還能說(shuō)明什么?覆蓋不覆蓋又有什么區(qū)別?
            @路人丁
              回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則 2009-04-10 09:40 cui
            用法,沒(méi)錯(cuò),只是你沒(méi)有判斷返回值,如果是重復(fù)插入,那么會(huì)返回pair<iterator, bool>.second = false, 不會(huì)出現(xiàn)內(nèi)存泄露的  回復(fù)  更多評(píng)論
              

            # re: STL容器誤用一則 2013-03-04 16:32 tb
            參考一下  回復(fù)  更多評(píng)論
              

            久久人人爽人人爽人人片AV麻烦 | 久久e热在这里只有国产中文精品99| 7国产欧美日韩综合天堂中文久久久久 | 97精品国产91久久久久久| 香蕉久久久久久狠狠色| 欧美午夜A∨大片久久| 精品欧美一区二区三区久久久| 青青热久久综合网伊人| 久久精品国产影库免费看| 色偷偷888欧美精品久久久| 国产成人无码精品久久久久免费 | 久久久久久亚洲精品无码| 精品久久久久久国产三级| 久久国产精品免费一区| 亚洲精品WWW久久久久久| 日韩精品久久久久久久电影| 亚洲va久久久噜噜噜久久狠狠| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 久久精品成人免费网站| 国产叼嘿久久精品久久| 一本久久a久久精品综合香蕉| 伊人久久精品无码二区麻豆| 99久久久精品| 久久精品一区二区影院| 国产亚洲精久久久久久无码77777| 亚洲国产一成人久久精品| 色噜噜狠狠先锋影音久久| 亚洲国产成人久久笫一页| 亚洲女久久久噜噜噜熟女| 26uuu久久五月天| 久久AV无码精品人妻糸列| 青青热久久综合网伊人| 亚洲午夜无码AV毛片久久| 久久久久久亚洲AV无码专区| 久久精品国产亚洲5555| 无码精品久久久天天影视| 久久国产影院| 国产精品一区二区久久不卡| 成人综合久久精品色婷婷| 久久国产精品99久久久久久老狼| 怡红院日本一道日本久久 |