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

力為的技術博客

聯系 聚合 管理
  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>
            亚洲无亚洲人成网站77777| 欧美日韩一区二区三区免费| 欧美jizzhd精品欧美巨大免费| 西瓜成人精品人成网站| 午夜在线精品偷拍| 午夜亚洲影视| 久久久久久夜| 亚洲高清不卡一区| 亚洲精品三级| 亚洲欧美国产77777| 久久精品99国产精品日本 | 国产精品美女久久久久av超清| 欧美日韩精品二区第二页| 欧美日韩精品二区| 国产酒店精品激情| 亚洲国产欧美在线人成| 一本在线高清不卡dvd| 午夜一区在线| 亚洲第一精品久久忘忧草社区| 亚洲美女中文字幕| 久久国产精品久久久| 欧美精品麻豆| 狠狠色丁香婷婷综合影院| 亚洲久色影视| 久久视频这里只有精品| 亚洲欧洲在线免费| 亚洲一区二区四区| 欧美成人精品影院| 国产亚洲毛片在线| 亚洲一区二区毛片| 亚洲黄色在线| 久久麻豆一区二区| 国产亚洲激情视频在线| 一本色道久久88精品综合| 蜜桃久久av| 国产精品久久久一本精品| 亚洲大胆在线| 久久精选视频| 亚洲五月六月| 欧美日韩国产在线播放网站| 激情久久中文字幕| 久久不射中文字幕| 一区二区三区不卡视频在线观看| 久久综合网hezyo| 国产一区二区三区四区老人| 亚洲欧美清纯在线制服| 99riav久久精品riav| 欧美成va人片在线观看| 在线观看一区视频| 久久综合久久88| 久久av一区二区| 国产色产综合色产在线视频| 午夜精品久久久久久久99樱桃| 亚洲人妖在线| 欧美激情1区| 亚洲精品小视频| 欧美大片在线观看一区二区| 久久人人97超碰国产公开结果| 国产永久精品大片wwwapp| 欧美一进一出视频| 亚洲欧美成人综合| 国产欧美亚洲精品| 欧美专区在线观看一区| 亚洲免费婷婷| 国产日本欧洲亚洲| 久久久精品五月天| 久久精品视频在线| 亚洲激情国产精品| 午夜久久tv| 欧美精品一区二区三区高清aⅴ| 亚洲精品国产精品乱码不99| 久久久精品国产免费观看同学| 亚洲一区www| 国产精品日韩精品欧美在线| 亚洲欧美在线视频观看| 亚洲一区在线观看免费观看电影高清| 欧美视频在线观看一区二区| 午夜精品剧场| 欧美在线精品免播放器视频| 影音先锋欧美精品| 欧美激情网友自拍| 欧美日韩国内自拍| 欧美在线啊v一区| 久久人人看视频| 亚洲精品色图| 亚洲欧美另类在线| 1769国产精品| 日韩午夜中文字幕| 国产在线高清精品| 亚洲福利视频一区| 国产精品高潮呻吟久久av黑人| 久久狠狠久久综合桃花| 欧美高清在线视频观看不卡| 亚洲一区视频| 久久午夜视频| 亚洲欧美精品伊人久久| 久久久久国产精品厨房| 亚洲一区二区三区精品视频| 久久久久久久精| 亚洲小说欧美另类婷婷| 久久免费高清视频| 午夜伦欧美伦电影理论片| 久久综合电影| 午夜精品国产更新| 男人的天堂亚洲在线| 久久国产精品99精品国产| 牛牛影视久久网| 久久久久久久高潮| 欧美日韩一区不卡| 亚洲国产精品va| 好看不卡的中文字幕| 中文久久精品| 99天天综合性| 美女国产一区| 免费成人在线观看视频| 国产日韩精品一区| 亚洲免费网址| 欧美一区二区播放| 欧美午夜精品一区二区三区| 亚洲高清不卡一区| 亚洲国产视频一区二区| 久久久久久伊人| 久久精品噜噜噜成人av农村| 国产精品成人一区二区网站软件| 亚洲欧洲视频| 亚洲欧洲在线看| 久久综合中文| 欧美国产成人在线| 91久久一区二区| 乱码第一页成人| 模特精品在线| 欧美综合国产| 欧美一区二区三区在线看| 欧美日韩在线视频一区| 亚洲破处大片| 日韩一二在线观看| 欧美劲爆第一页| 亚洲精品中文字幕有码专区| 夜夜嗨网站十八久久| 欧美日韩在线不卡| 亚洲视频电影图片偷拍一区| 亚洲影音一区| 国产精品中文字幕欧美| 亚洲欧美日韩一区二区三区在线观看 | 久久久国产精品亚洲一区| 国产精品专区h在线观看| 亚洲综合视频1区| 久久久久久夜精品精品免费| 黄色亚洲网站| 欧美成人午夜激情在线| 亚洲人成亚洲人成在线观看图片 | 久久精品国产亚洲a| 久热国产精品| 亚洲伦理久久| 欧美日韩在线一区二区三区| 在线亚洲精品| 久久久福利视频| 亚洲高清视频的网址| 欧美福利一区| 在线亚洲精品| 久久资源av| 一本在线高清不卡dvd | 99xxxx成人网| 久久久激情视频| 亚洲经典在线| 国产精品v亚洲精品v日韩精品 | 在线观看日韩一区| 欧美华人在线视频| 亚洲一区二区三区精品在线| 久久免费视频在线| 日韩视频一区二区| 国产午夜精品全部视频播放| 免费不卡欧美自拍视频| 一区二区三区蜜桃网| 免费看黄裸体一级大秀欧美| 一区二区成人精品| 激情国产一区| 欧美午夜宅男影院| 久久久久一区二区三区| 在线性视频日韩欧美| 久久亚洲欧洲| 亚洲自拍偷拍网址| 亚洲国产日日夜夜| 国产精品永久免费在线| 欧美电影免费| 久久精品国产久精国产思思| 日韩亚洲欧美在线观看| 久久一区欧美| 亚洲欧美日韩爽爽影院| 亚洲欧洲美洲综合色网| 国产亚洲欧美日韩在线一区| 亚洲电影免费观看高清完整版在线 | 欧美日韩在线免费视频| 久久久久一区二区| 亚洲欧美激情一区| aⅴ色国产欧美| 欧美大片在线观看一区二区| 久久精品人人爽| 亚洲欧美在线看| 亚洲一区二区av电影|