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

勤能補(bǔ)拙,Expter

成都游戲Coder,記錄游戲開發(fā)過程的筆記和心得!

一個(gè)關(guān)于容器選取的刪除問題。


問題描述:
1個(gè)容器有大量元素,需要進(jìn)行erase大部分?jǐn)?shù)據(jù)的時(shí)候,需要遍歷這些元素,然后釋放item的空間,還要erase刪除其item。

一個(gè)庫,為了測試其性能的時(shí)候,需要保存所有外部使用者的數(shù)據(jù),這里選取了map,vector和list.

為了簡化問題,我寫了下面測試代碼來測試各個(gè)操作:
數(shù)據(jù)節(jié)點(diǎn):

struct node
{
    node(
int i){data = i;}
    
int data;
}

 1int _tmain(int argc, _TCHAR* argv[])
 2{
 3    typedef std::map<long,node*> Mptable;
 4    typedef std::vector<node*>   Vec;
 5    typedef std::list<node*>     List;
 6    
 7    Mptable        mapnode;
 8    Vec            vecnode;
 9    List        listnode;
10
11    for(int i = 1 ; i <= 100000 ; i++ )
12    {     
13        mapnode [ i ] = new node(i);
14        vecnode.push_back( new node(i) );
15        listnode.push_back( new node(i));
16    }

17
18    long time = timeGetTime( );
19    
20    for( Mptable::iterator itr = mapnode.begin() ; itr != mapnode.end() ;  )
21    {
22         delete itr->second;
23         mapnode.erase( itr++ );
24    }

25
26    std::cout <<"map : spend " << timeGetTime() - time << " msec " << std::endl;
27
28
29    time = timeGetTime( );
30    
31    for( Vec::iterator itr = vecnode.begin() ; itr != vecnode.end() ;  )
32    {
33         delete *itr;
34         itr = vecnode.erase( itr );
35    }

36
37    std::cout <<"vector : spend " << timeGetTime() - time << " msec " << std::endl;
38
39
40    time = timeGetTime( );
41    
42    for( List::iterator itr = listnode.begin() ; itr != listnode.end() ;  )
43    {
44         delete *itr;
45         itr = listnode.erase( itr );
46    }

47
48    std::cout <<"list : spend " << timeGetTime() - time << " msec" << std::endl;
49
50
51    return 0;
52}
Release下運(yùn)行結(jié)果:
map : spend 31 msec
vector : spend 3734 msec
list : spend 35 msec


發(fā)現(xiàn)map的速度最快,vector最慢,list相當(dāng)。

其實(shí)vector就是一個(gè)Array,只是Array是靜態(tài)大小,vector可以擴(kuò)展,然后查看vector的erase的源碼:
iterator erase(const_iterator _Where)
        
{    // erase element at where
        _Move(_VIPTR(_Where) + 1this->_Mylast,
            _VIPTR(_Where));
        _Destroy(
this->_Mylast - 1this->_Mylast);
        
--this->_Mylast;
        
return (_Make_iter(_Where));
        }
有一個(gè)move操作,原來把當(dāng)前iterator+1的往前移了,這樣的話會(huì)遍歷iterator后面所有的元素。


關(guān)于map的erase原理可以查看map的實(shí)現(xiàn)源碼:
由于map的erase后有一個(gè)維護(hù)過程,其實(shí)map是一個(gè)RB-Tree,刪除算法相對(duì)比較麻煩,刪除某個(gè)item會(huì)查找下一個(gè)item替換刪除的節(jié)點(diǎn),同時(shí)還要考慮紅和黑的節(jié)點(diǎn)處理。同時(shí)還要保證map的erase后,平衡且有序。
所以map的erase主要做:
1.刪除item.
2.讓樹平衡,且有序。

list其實(shí)是一個(gè)雙向鏈表:
關(guān)于刪除其實(shí)是0(1)的操作,我們查看list的erase的操作:
    iterator erase(const_iterator _Where)
        
{    // erase element at _Where
 #if _ITERATOR_DEBUG_LEVEL == 2
        
if (_Where._Getcont() != this || _Where._Ptr == this->_Myhead)
            _DEBUG_ERROR(
"list erase iterator outside range");
        _Nodeptr _Pnode 
= (_Where++)._Mynode();
        _Orphan_ptr(
*this, _Pnode);

 
#else /* _ITERATOR_DEBUG_LEVEL == 2 */
        _Nodeptr _Pnode 
= (_Where++)._Mynode();
 
#endif /* _ITERATOR_DEBUG_LEVEL == 2 */

        
if (_Pnode != this->_Myhead)
            
{    // not list head, safe to erase
            this->_Nextnode(this->_Prevnode(_Pnode)) =
                
this->_Nextnode(_Pnode);
            
this->_Prevnode(this->_Nextnode(_Pnode)) =
                
this->_Prevnode(_Pnode);

            _Dest_val(
this->_Alnod, _Pnode);
            
this->_Alnod.deallocate(_Pnode, 1);

            
--this->_Mysize;
            }

        
return (_Make_iter(_Where));
        }
主要代碼刪除就是下面刪除部分:
對(duì)prev和next節(jié)點(diǎn)進(jìn)行處理即可。

關(guān)于list的移除竟然比map還要慢.

PS:測試為單線程。

當(dāng)為100W數(shù)據(jù)的時(shí)候:
map : spend 300 msec
list :   spend 385 msec

咋list比map容器還要慢?
還是上面的代碼不能說明問題。

posted on 2011-01-14 14:58 expter 閱讀(2614) 評(píng)論(2)  編輯 收藏 引用 所屬分類: 其他學(xué)習(xí)筆記工作筆記算法與數(shù)據(jù)結(jié)構(gòu)

評(píng)論

# re: 一個(gè)關(guān)于容器選取的刪除問題。 2011-01-17 18:42 小笨象

如果vector從最后一個(gè)開始刪除呢?
有沒有試過?  回復(fù)  更多評(píng)論   

# re: 一個(gè)關(guān)于容器選取的刪除問題。 2011-01-18 00:09 expter

@小笨象
你說那個(gè)確實(shí)可以提高效率。

只是不解禁用優(yōu)化后,list比map快,不禁用map缺比list快。。
  回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产精品第一页| 裸体素人女欧美日韩| 亚洲免费一在线| 亚洲成色最大综合在线| 国产精品久久久999| 欧美日韩另类综合| 国产精品v亚洲精品v日韩精品| 美女脱光内衣内裤视频久久网站| 欧美在线你懂的| 欧美尤物巨大精品爽| 久久9热精品视频| 每日更新成人在线视频| 欧美freesex交免费视频| 欧美激情视频一区二区三区在线播放 | 欧美日本在线观看| 国产精品wwwwww| 国产精品欧美精品| 黄色精品在线看| 亚洲精品久久久久久下一站 | 亚洲靠逼com| 在线性视频日韩欧美| 亚洲一区二区免费视频| 欧美在线欧美在线| 久久综合亚州| 亚洲另类春色国产| 亚洲天堂第二页| 久久精品国产一区二区三| 农夫在线精品视频免费观看| 欧美特黄一级| 一区二区三区亚洲| 一本久道久久综合狠狠爱| 欧美一区二区三区久久精品茉莉花 | 久久久久久亚洲综合影院红桃| 欧美xxx成人| 国产乱码精品一区二区三| 尤物在线精品| 午夜在线视频观看日韩17c| 久久综合精品一区| 在线中文字幕一区| 欧美成人一品| 国模套图日韩精品一区二区| 日韩视频国产视频| 久久久久久成人| 亚洲视频你懂的| 欧美成人精品高清在线播放| 国产精自产拍久久久久久| 亚洲精品国产欧美| 久久综合给合久久狠狠色| 国产精品99久久久久久有的能看| 久久五月激情| 国产在线欧美| 亚洲女人天堂成人av在线| 亚洲黄网站在线观看| 在线综合+亚洲+欧美中文字幕| 久久夜色精品国产欧美乱极品| 国产精品国内视频| 亚洲欧洲日产国产综合网| 久久午夜影视| 性欧美暴力猛交69hd| 国产精品普通话对白| 亚洲视频 欧洲视频| 欧美国产欧美综合 | 欧美视频在线一区二区三区| 亚洲国内精品在线| 母乳一区在线观看| 久久综合国产精品| 亚洲高清自拍| 欧美不卡视频一区发布| 久久久精品一品道一区| 精品成人一区| 蜜桃av综合| 欧美一区=区| 国产亚洲欧美日韩日本| 国产一区二区三区观看| 欧美一区二区三区喷汁尤物| 中国亚洲黄色| 国产精品毛片a∨一区二区三区| 在线视频日韩| 亚洲综合社区| 国产一区二区三区久久| 久久激情网站| 久久全国免费视频| 91久久精品日日躁夜夜躁国产| 欧美成人免费在线观看| 美女视频黄免费的久久| 一区二区三区www| 亚洲视频精品| 国产日韩一区二区三区| 开心色5月久久精品| 久久综合色天天久久综合图片| 亚洲国产成人不卡| 99pao成人国产永久免费视频| 欧美视频一区二区三区…| 亚洲欧美日韩综合国产aⅴ| 欧美一区二区三区视频在线观看 | 在线视频欧美日韩| 午夜精品久久久久| 在线欧美电影| 日韩视频一区二区三区| 国产精品午夜视频| 免费成人av在线看| 欧美日韩一区三区四区| 久久一区二区三区国产精品| 欧美精品一区二区三| 午夜精品一区二区三区在线| 久久精品99无色码中文字幕| 亚洲九九精品| 亚洲欧美日本日韩| 亚洲人成高清| 香蕉亚洲视频| 日韩视频一区| 久久激情视频免费观看| av不卡在线看| 久久久久一区二区三区| 一本色道**综合亚洲精品蜜桃冫 | 亚洲午夜视频在线观看| 136国产福利精品导航| 一级日韩一区在线观看| 在线国产日韩| 亚洲一区三区电影在线观看| 最新精品在线| 香蕉久久夜色精品| 亚洲一区影音先锋| 免费观看在线综合| 久久久久国产精品一区| 欧美日韩在线视频一区| 蜜臀av国产精品久久久久| 国产精品日韩在线一区| 亚洲精品小视频| 最新国产成人在线观看| 久久久91精品国产一区二区精品| 亚洲资源av| 欧美日韩精品免费观看视频完整| 91久久国产综合久久| 亚洲欧美日韩国产综合精品二区| 亚洲国产精品成人一区二区| 欧美一区二区三区的| 亚洲永久免费精品| 欧美日本视频在线| 亚洲精品1区| 亚洲国产精品悠悠久久琪琪| 久久久国产精品一区二区三区| 亚洲欧美日韩中文视频| 欧美视频一区二区三区在线观看| 亚洲国产一区二区视频| 亚洲国产日韩欧美综合久久| 久久久一区二区三区| 麻豆成人综合网| 亚洲欧洲日产国码二区| 欧美www视频| 亚洲精品一区二区三区樱花| 亚洲免费播放| 欧美伦理在线观看| 亚洲精品一区二区三区四区高清| 99日韩精品| 国产精品久久久久久久第一福利 | 一区二区免费在线播放| 一区二区三区av| 国产精品成人免费视频| 亚洲一区二区精品在线| 亚洲欧美中文日韩v在线观看| 欧美午夜不卡影院在线观看完整版免费| 亚洲激情在线播放| 亚洲一区在线直播| 国产亚洲精品美女| 久久人91精品久久久久久不卡| 久久综合影音| 亚洲人久久久| 国产精品xxxav免费视频| 亚洲欧美激情四射在线日 | 午夜精品视频在线观看一区二区| 国产精品白丝av嫩草影院| 亚洲自拍偷拍一区| 免费在线日韩av| 亚洲一区二区av电影| 国产日韩亚洲欧美精品| 久久亚洲美女| 夜夜夜精品看看| 久久久天天操| 日韩午夜电影av| 国产精品视频一区二区三区| 欧美一区二区免费视频| 亚洲精品久久久久久久久久久| 欧美亚洲网站| 亚洲欧洲日本一区二区三区| 国产精品久久久久国产精品日日 | 久久黄金**| 一区二区三区免费网站| 久久综合狠狠综合久久综合88| 在线视频日本亚洲性| 国内精品一区二区三区| 欧美精品久久天天躁| 久久精品亚洲精品国产欧美kt∨| 亚洲欧洲精品一区二区三区 | 久久久蜜桃一区二区人| 一区二区三区成人| 狠狠久久婷婷| 国产精品免费观看在线| 欧美电影免费| 午夜在线视频观看日韩17c|