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

            力為的技術博客

            聯系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

            一、需求:

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

            二、"解決"方法:

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

            先寫一個函數對象:

            // 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;


            這種方法有啥問題?
            (見文后)

            2. 使用std::list
            list中的元素默認不會排序,需要我們“手動”排序。
            用list這樣聲明:

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


            添加完元素后,再排序:

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

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


            (2)使用list.sort()

            listContainer.sort(CompareObject());


            三、分析

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

            評論

            # re: STL容器誤用一則 2009-03-11 09:12 路人丁
            "但現在set中存放的是指針,于是內存便泄漏了。" --- 只能說明你設計錯誤,既然你存指針,那么就應該自己保證釋放;

            “假如要插入的元素在set中已經存在會發生什么呢?是用新的元素替換原來的元素還是保留原來的元素呢?” --- 容器選擇錯誤,如果你想保存相等值,那么應當用multiset,而不是set。  回復  更多評論
              

            # re: STL容器誤用一則 2009-03-11 09:18 力為
            @路人丁
            兄弟說的對。標題說的就是誤用,肯定是設計的問題:),也就是說此處用set是肯定有問題的。  回復  更多評論
              

            # re: STL容器誤用一則 2009-03-11 09:22 Kevin Lynx
            存檔的指針指向的內存是由你自己來維護的,不是set來維護,所有有內存泄露,也是你自己的錯誤。

            std::sort不能對std::list進行排序,那是因為std::sort只能對random-access iterator進行操作,std::list::iterator不是random-access的。所以std::list才自己提供了sort函數。

            詳細參看std::sort文檔  回復  更多評論
              

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

            # re: STL容器誤用一則 2009-03-11 12:10 yindf
            容器里存放對象指針,一般建議用smart_ptr.
            原生指針遇到多態,就哭了。  回復  更多評論
              

            # re: STL容器誤用一則[未登錄] 2009-03-11 12:16 apan
            關于STL中的sort函數,看看這篇文章
            http://www.stlchina.org/twiki/bin/view.pl/Main/STLSortAlgorithms  回復  更多評論
              

            # re: STL容器誤用一則[未登錄] 2009-03-11 22:09 koobin
            “假如要插入的元素在set中已經存在會發生什么呢?是用新的元素替換原來的元素還是保留原來的元素呢?”
            你的set中存放的是指針,如果已經存在,那還能說明什么?覆蓋不覆蓋又有什么區別?
            @路人丁
              回復  更多評論
              

            # re: STL容器誤用一則 2009-04-10 09:40 cui
            用法,沒錯,只是你沒有判斷返回值,如果是重復插入,那么會返回pair<iterator, bool>.second = false, 不會出現內存泄露的  回復  更多評論
              

            # re: STL容器誤用一則 2013-03-04 16:32 tb
            參考一下  回復  更多評論
              

            国产成人无码精品久久久性色| 久久久久久久久久久久中文字幕 | 看全色黄大色大片免费久久久 | 久久综合色老色| 久久久精品波多野结衣| 国内精品久久久久久不卡影院| 91精品国产综合久久精品| 久久综合香蕉国产蜜臀AV| 亚洲AV无码久久寂寞少妇| 日韩人妻无码精品久久久不卡| 久久精品国产亚洲AV嫖农村妇女 | 久久精品国产免费观看三人同眠| 色天使久久综合网天天| 午夜精品久久久久久影视riav| 色偷偷88888欧美精品久久久| 色偷偷久久一区二区三区| 国产午夜精品理论片久久影视| 久久99精品国产一区二区三区| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 午夜福利91久久福利| 午夜不卡久久精品无码免费| 久久99精品久久久久子伦| 久久国产影院| 亚洲欧美成人综合久久久| 久久久老熟女一区二区三区| 伊人久久大香线蕉影院95| 久久天天躁夜夜躁狠狠| 国产精品久久久久久一区二区三区| 亚洲国产精品人久久| 99久久精品免费看国产一区二区三区 | 色婷婷久久综合中文久久蜜桃av| 国产精品视频久久久| 亚洲国产精品嫩草影院久久| 久久精品国产精品亚洲毛片| 国产精品免费看久久久香蕉| 国内高清久久久久久| 99久久综合国产精品二区| 日韩精品久久久肉伦网站| 无码人妻少妇久久中文字幕| 97久久香蕉国产线看观看| 久久精品卫校国产小美女|