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

力為的技術博客

聯系 聚合 管理
  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 力為 閱讀(2836) 評論(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>
            欧美一级在线播放| 久久精品夜色噜噜亚洲aⅴ | 久久亚洲精品伦理| 欧美一区网站| 亚洲福利视频网站| 亚洲国产专区校园欧美| 欧美精品在线一区| 亚洲视频中文| 欧美亚洲系列| 亚洲精品免费观看| 一区二区三区四区国产精品| 欧美图区在线视频| 久久婷婷亚洲| 欧美精品久久久久久久久老牛影院| 一区二区欧美国产| 午夜精品久久久久久99热| 影音国产精品| 在线一区欧美| 好吊色欧美一区二区三区视频| 欧美福利视频网站| 国产精品成人一区二区艾草| 久久九九久精品国产免费直播 | 亚洲一级特黄| 影音先锋在线一区| 日韩一区二区福利| 一区二区视频在线观看| 亚洲精品一区二区三区不| 国产欧美日韩一级| 亚洲三级免费观看| 国产婷婷色一区二区三区在线 | 午夜精品久久久久久久久久久久| 久久国产乱子精品免费女 | 亚洲人妖在线| 午夜精品久久久久| 中日韩美女免费视频网站在线观看| 午夜精品国产| 一区二区三区视频在线观看| 欧美自拍偷拍| 亚洲欧美在线免费| 欧美日韩国产首页在线观看| 久久午夜电影网| 国产精品国产a级| 亚洲精品视频一区二区三区| 国产精品乱人伦中文| 最新高清无码专区| 在线观看日韩www视频免费| 亚洲欧美日韩国产综合| 99热在线精品观看| 欧美成人有码| 欧美激情va永久在线播放| 国产一区二区毛片| 午夜在线精品偷拍| 香蕉久久一区二区不卡无毒影院| 欧美日韩一区二区三区免费看| 欧美国产专区| 亚洲国产经典视频| 久久免费国产精品| 久久婷婷亚洲| 在线播放亚洲一区| 久久天天躁狠狠躁夜夜av| 久久精品视频99| 国产日韩欧美一区二区| 亚洲欧美另类在线| 欧美在线观看网址综合| 国产精品网站一区| 亚洲永久免费av| 欧美一区二区久久久| 国产精品亚洲不卡a| 亚洲综合精品| 久久成人av少妇免费| 国产视频亚洲精品| 久久久999成人| 欧美成人亚洲| 亚洲黄色成人久久久| 欧美黄色aa电影| 99国产精品国产精品久久| 亚洲视频在线观看三级| 国产精品扒开腿做爽爽爽软件| 一区二区三区四区国产精品| 亚洲欧美日韩精品久久奇米色影视 | 久久精品国产清自在天天线| 国产日韩综合一区二区性色av| 久久激情五月婷婷| 亚洲第一精品福利| 在线亚洲欧美| 国产一区二区三区观看| 狂野欧美性猛交xxxx巴西| 亚洲第一毛片| 亚洲女同在线| 一区二区在线观看视频| 欧美精品免费视频| 亚洲尤物精选| 欧美成人国产| 亚洲欧美日韩精品久久亚洲区 | 欧美日韩亚洲国产精品| 亚洲男人的天堂在线| 免费国产自线拍一欧美视频| 亚洲人成亚洲人成在线观看| 欧美视频一区二区三区| 欧美一级在线亚洲天堂| 亚洲日本aⅴ片在线观看香蕉| 亚洲在线网站| 亚洲国产精品一区二区www| 欧美性理论片在线观看片免费| 欧美一级播放| 一区二区电影免费观看| 久久久国产视频91| 亚洲一区二区不卡免费| 亚洲第一偷拍| 国产欧美日韩视频一区二区三区 | 久久精品男女| avtt综合网| 亚洲第一在线| 久久精品导航| 亚洲一区二区在线看| 亚洲激情另类| 国语自产偷拍精品视频偷 | 国产精品v欧美精品∨日韩| 久久精品中文字幕一区二区三区| 9i看片成人免费高清| 欧美成人一区二免费视频软件| 欧美一区亚洲一区| 中国成人在线视频| 亚洲精品资源| 亚洲日本黄色| 亚洲国产精品一区二区尤物区| 国产日产高清欧美一区二区三区| 欧美日韩少妇| 欧美精品一区二区精品网| 久久亚洲欧洲| 久久精品视频亚洲| 欧美在线观看网站| 午夜精品福利一区二区三区av| 一区二区福利| 国产精品99久久久久久www| 亚洲激情视频网站| 欧美国产精品中文字幕| 欧美69视频| 美女视频黄 久久| 免费成人在线观看视频| 欧美在线你懂的| 久久成人精品视频| 久久久久久9| 久久精品日韩一区二区三区| 久久riav二区三区| 久久久福利视频| 久久一区亚洲| 欧美电影免费观看大全| 亚洲国产91| 亚洲精品永久免费精品| 夜夜爽夜夜爽精品视频| 亚洲午夜久久久久久久久电影院 | 狠狠久久五月精品中文字幕| 国产一区二区精品久久99| 黑人巨大精品欧美黑白配亚洲| 国内精品视频在线播放| 一区二区视频免费在线观看 | 亚洲人成网站色ww在线| 亚洲精品久久久久久久久久久久久| 亚洲精品国产无天堂网2021| 99国产精品99久久久久久| 亚洲摸下面视频| 久久久久久黄| 亚洲高清电影| 亚洲午夜羞羞片| 久久女同精品一区二区| 欧美黄色免费网站| 国产精品久久久久久久久搜平片| 国产午夜精品美女毛片视频| 精品动漫3d一区二区三区免费版 | 一区二区高清| 欧美在线视频全部完| 麻豆精品视频在线观看| 亚洲国产一区二区视频| 亚洲视频精选在线| 久久久精品国产99久久精品芒果| 美女国产一区| 国产精品免费一区二区三区观看| 有坂深雪在线一区| 亚洲欧美美女| 欧美电影在线播放| 亚洲女女女同性video| 久久一区二区视频| 国产精品一级久久久| 亚洲国产一区二区三区高清| 亚洲欧美制服中文字幕| 欧美寡妇偷汉性猛交| 亚洲一区bb| 欧美激情一区在线| 国产色视频一区| 亚洲一区二区免费看| 久久综合九色欧美综合狠狠| 99亚洲一区二区| 欧美α欧美αv大片| 国产视频精品xxxx| 亚洲一区二区免费看| 亚洲国产精品第一区二区| 久久精品视频网| 国产农村妇女毛片精品久久麻豆| 一区二区欧美在线|