青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

力為的技術博客

聯系 聚合 管理
  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 力為 閱讀(2834) 評論(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
參考一下  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲深夜福利在线| 国产亚洲福利社区一区| 欧美成人中文字幕| 亚洲一区二区三区在线| 伊人春色精品| 国产欧美日韩三级| 欧美午夜不卡在线观看免费 | 国内精品久久久| 欧美视频一区二区在线观看| 久久一区国产| 麻豆成人在线| 久久婷婷色综合| 美女爽到呻吟久久久久| 久久久久欧美| 麻豆成人小视频| 欧美.www| 欧美伦理视频网站| 欧美深夜福利| 黄色日韩精品| 亚洲在线视频观看| 99精品欧美一区二区三区| 亚洲高清视频在线观看| 免费一级欧美片在线观看| 久久久久高清| 免费成人毛片| 亚洲成色777777在线观看影院| 欧美91视频| 欧美激情第二页| 亚洲高清视频在线| 99精品热视频| 午夜在线成人av| 久久久精品一区二区三区| 老司机午夜精品视频| 欧美顶级大胆免费视频| 欧美精品一区二区视频| 国产精品mv在线观看| 国产日韩欧美中文| 亚洲电影免费观看高清完整版在线观看 | 日韩一级精品| 亚洲手机在线| 久久久蜜桃精品| 亚洲国产精品一区制服丝袜| 亚洲美女性视频| 西瓜成人精品人成网站| 久久午夜精品一区二区| 欧美日本视频在线| 国产美女一区| 亚洲欧洲在线播放| 欧美中文字幕视频| 亚洲电影免费观看高清完整版| 亚洲免费观看高清完整版在线观看熊| 亚洲一区二区三| 欧美成人国产va精品日本一级| 欧美午夜免费影院| 在线观看欧美| 午夜亚洲福利| 亚洲国产你懂的| 欧美一区二区三区在线| 欧美美女日韩| 在线免费观看欧美| 亚洲欧美日韩一区二区三区在线观看 | 一区二区三区|亚洲午夜| 一区二区日韩| 久久久综合精品| 国产精品mm| 亚洲人成网站精品片在线观看| 亚洲欧洲三级| 久久精品国产欧美激情| 亚洲风情亚aⅴ在线发布| 亚洲作爱视频| 亚洲欧美激情视频在线观看一区二区三区 | 国产麻豆精品在线观看| 99精品99| 欧美激情第10页| 久久综合给合| 国产亚洲一区精品| 欧美中文字幕久久| 亚洲视频狠狠| 国产精品国产三级国产普通话三级| 亚洲国产精品va| 欧美成年网站| 久久香蕉国产线看观看av| 国产欧美一区二区白浆黑人| 亚洲韩国精品一区| 久久精品女人的天堂av| 午夜激情亚洲| 欧美日韩亚洲一区二| 99精品视频免费观看| 久久亚洲综合色| 久久精品日韩欧美| 国产美女诱惑一区二区| 亚洲欧美制服中文字幕| 亚洲一区二区三区四区在线观看 | 亚洲日韩欧美视频一区| 欧美激情第一页xxx| 牛牛影视久久网| 日韩视频不卡| 一区二区精品国产| 国产精品久久9| 久久高清福利视频| 久久久久久久91| 亚洲国产一区在线| 最新中文字幕亚洲| 欧美日韩国产一中文字不卡| 亚洲一区日韩在线| 欧美在线亚洲在线| 亚洲人成在线观看网站高清| 亚洲精品久久久久久久久久久 | 99热精品在线| 亚洲专区欧美专区| 黄色精品免费| 亚洲国产另类久久久精品极度| 欧美日本在线| 欧美一区二区三区视频免费播放| 欧美在线亚洲在线| 欧美在线亚洲| 欧美日韩免费观看中文| 亚洲在线电影| 午夜精品av| 91久久精品国产91久久性色| 日韩亚洲欧美一区| 国产一区二区三区四区在线观看 | 国产欧美日韩免费| 亚洲国产91精品在线观看| 国产精品va在线播放| 久久精品在这里| 欧美理论电影网| 久久精品中文| 欧美午夜精品久久久久久孕妇 | 国产精品美女午夜av| 久久精视频免费在线久久完整在线看 | 欧美日韩国产在线| 美女精品在线观看| 国产乱理伦片在线观看夜一区| 欧美高清视频一二三区| 欧美日韩综合在线| 老司机免费视频久久| 欧美三区美女| 亚洲国产精品毛片| 国产香蕉久久精品综合网| 亚洲精品自在在线观看| 国产精品国产三级国产aⅴ9色| 欧美/亚洲一区| 亚洲图片欧洲图片日韩av| 久久久久青草大香线综合精品| 亚洲影院在线观看| 欧美国产在线电影| 美女图片一区二区| 欧美小视频在线观看| 欧美阿v一级看视频| 国产一区二区日韩| 先锋影音久久| 午夜国产精品影院在线观看 | 国产主播精品在线| 亚洲视频一起| 亚洲一区高清| 欧美日韩久久精品| 91久久精品久久国产性色也91 | 欧美中文在线视频| 国产精品少妇自拍| 亚洲天堂av在线免费| 亚洲午夜精品一区二区| 欧美日韩国产精品一卡| 亚洲经典一区| 99亚洲视频| 欧美日韩另类国产亚洲欧美一级| 亚洲日本久久| 在线精品一区| 麻豆久久久9性大片| 亚洲精品1234| 久久成人免费视频| 国外精品视频| 欧美在线亚洲在线| 久久久久久九九九九| 国产亚洲精品bv在线观看| 午夜久久一区| 久久一日本道色综合久久| 伊人婷婷欧美激情| 欧美1区2区| 在线视频你懂得一区| 久热这里只精品99re8久| 亚洲看片一区| 狠狠色丁香久久婷婷综合_中| 欧美国产日韩一区二区三区| 一区二区三区黄色| 欧美高清在线视频| 校园春色国产精品| 亚洲成人自拍视频| 国产精品激情| 老司机精品福利视频| 亚洲欧美资源在线| 亚洲精品一区二区三区樱花| 久久午夜国产精品| 亚洲午夜久久久久久尤物 | 久久精品国产免费看久久精品| 亚洲国产视频a| 久久视频这里只有精品| 午夜欧美精品| 在线视频欧美精品| 亚洲电影免费观看高清完整版在线观看 |