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

力為的技術博客

聯系 聚合 管理
  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>
            欧美日韩直播| 亚洲经典视频在线观看| 在线观看中文字幕亚洲| 国产亚洲高清视频| 好吊日精品视频| 在线观看中文字幕亚洲| 亚洲黄色免费| 亚洲无线一线二线三线区别av| 亚洲精品系列| 亚洲欧美国产精品va在线观看 | 久久久久久国产精品mv| 久久久91精品国产| 欧美69视频| 国产一区二区电影在线观看| 国内精品久久久久影院色 | 久久亚洲春色中文字幕久久久| 久久久精品国产免费观看同学| 免费成年人欧美视频| 亚洲高清av在线| 一区二区黄色| 久久久久久亚洲精品杨幂换脸 | 夜夜嗨网站十八久久| 亚洲一区二区在线视频 | 制服诱惑一区二区| 久久www免费人成看片高清| 欧美成人免费网站| 国产精品中文在线| 亚洲国产精品v| 午夜精品久久久久久久蜜桃app| 玖玖在线精品| 一本色道久久综合亚洲精品不| 久久精品国产999大香线蕉| 欧美日本国产在线| 1204国产成人精品视频| 小黄鸭精品aⅴ导航网站入口| 亚洲福利在线看| 久久久五月婷婷| 国产乱码精品| 亚洲伊人网站| 亚洲国产小视频| 久久精品国产999大香线蕉| 国产精品国产馆在线真实露脸 | 亚洲激情国产精品| 久久疯狂做爰流白浆xx| 亚洲美女诱惑| 欧美成人一区二区三区| 国内成+人亚洲+欧美+综合在线| 一区二区免费在线视频| 亚洲第一区在线| 久久久亚洲一区| 国语自产精品视频在线看8查询8| 亚洲欧美电影在线观看| aa级大片欧美三级| 国产乱码精品一区二区三区不卡| 亚洲国产欧美一区| 美女国产精品| 最新亚洲视频| 欧美成人中文字幕| 麻豆精品传媒视频| 亚洲人成在线播放网站岛国| 欧美a一区二区| 免费观看日韩| 免费亚洲一区二区| 狠狠色香婷婷久久亚洲精品| 久久精品水蜜桃av综合天堂| 亚洲女爱视频在线| 国产午夜精品久久| 久久久久欧美| 久久精品99国产精品日本| 激情六月婷婷久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美专区在线观看一区| 激情久久婷婷| 亚洲第一福利社区| 欧美色图首页| 久久精品国产清自在天天线| 久久爱www.| 91久久线看在观草草青青| 亚洲激情视频在线| 国产精品久久久久影院亚瑟 | 欧美a级大片| 蜜桃精品久久久久久久免费影院| 亚洲国产精品va在线看黑人动漫 | 久久国产一二区| 在线播放豆国产99亚洲| 亚洲高清毛片| 国产精品免费观看在线| 久久全球大尺度高清视频| 美女精品在线观看| 午夜精品久久久久| 欧美中文日韩| 一区二区欧美视频| 欧美在线视频网站| 亚洲另类春色国产| 亚洲女人天堂av| 亚洲黄色高清| 亚洲欧美成人网| 91久久国产综合久久蜜月精品| av不卡免费看| 欲色影视综合吧| 日韩午夜电影在线观看| 国产一区二区av| 夜夜嗨一区二区| 亚洲国产精品日韩| 亚洲一区精品视频| 91久久综合亚洲鲁鲁五月天| 亚洲影视在线播放| 亚洲激情在线观看视频免费| 亚洲一区二区三区精品在线观看| 影音先锋国产精品| 亚洲免费视频中文字幕| 日韩亚洲精品视频| 久久久国产精品一区| 亚洲视频在线播放| 鲁大师影院一区二区三区| 性欧美超级视频| 欧美日韩精品三区| 欧美激情国产高清| 国内精品免费在线观看| 亚洲一区二区三区在线播放| 91久久亚洲| 久久久国际精品| 久久国产精品毛片| 国产精品日韩在线一区| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲天堂偷拍| 亚洲精品午夜| 欧美国产三级| 美女图片一区二区| 国产尤物精品| 性欧美大战久久久久久久久| 亚洲午夜女主播在线直播| 欧美精品少妇一区二区三区| 亚洲高清网站| 亚洲免费电影在线| 欧美成人国产va精品日本一级| 麻豆久久精品| 亚洲国产欧美久久| 欧美成人一品| 日韩天天综合| 欧美一级大片在线免费观看| 国产精品一区二区在线观看网站| 亚洲在线电影| 久久国产综合精品| 国产一区自拍视频| 久久这里有精品视频| 亚洲国产高清视频| 一区二区三区 在线观看视| 欧美日韩亚洲三区| 亚洲桃花岛网站| 久久久91精品国产| 亚洲激情av在线| 欧美日韩在线播放三区| 一本一本久久| 欧美在线视频二区| 伊人久久噜噜噜躁狠狠躁| 欧美/亚洲一区| 日韩视频免费| 欧美一区二区三区在线观看| 国产主播精品| 免费不卡在线观看av| 亚洲开发第一视频在线播放| 亚洲欧美国产不卡| 在线播放精品| 欧美日韩亚洲不卡| 欧美影院成人| 亚洲乱亚洲高清| 久久精品日产第一区二区| 亚洲国产精品久久久久| 欧美视频一区二区在线观看| 欧美在线免费观看视频| 亚洲欧洲一区二区三区久久| 性欧美1819sex性高清| 亚洲第一精品夜夜躁人人爽| 欧美日韩国产成人在线| 久久国产精品久久久久久| 亚洲国产天堂久久综合| 欧美在线三级| 夜夜爽99久久国产综合精品女不卡| 国产精品免费小视频| 免费亚洲电影在线| 欧美一级播放| 9色精品在线| 亚洲国产精品美女| 欧美在线观看视频在线| 亚洲免费福利视频| 樱花yy私人影院亚洲| 国产精品亚洲一区| 欧美黑人在线播放| 久久精品一区四区| 亚洲影视在线播放| 亚洲免费观看高清完整版在线观看熊| 久久国产直播| 午夜精品美女自拍福到在线| 日韩视频一区二区三区| 久久夜色精品国产欧美乱极品| 99视频精品| 亚洲人成在线播放| 欧美顶级艳妇交换群宴| 久久一区二区三区av|