• <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>
            隨筆-90  評論-947  文章-0  trackbacks-0

            我作了雙向擴充實現(xiàn)。昨天的方案是:

            先判斷插入的元素靠前還是靠后,靠哪邊就準備往哪邊挪舊元素,然后檢查那頭有沒有空,沒空換另一頭,要是都沒空但兩頭加起來卻有空,那就重新調(diào)整位置,最后才重新分配空間。

            我原以為考慮得好周到,可是實現(xiàn)起來卻傻了眼。往末尾插入10萬數(shù)據(jù),有9萬多次發(fā)生移動元素,不慢才怪。

             

            調(diào)整了下,變成:

            先判斷考前還是靠后,靠哪邊就往哪邊挪舊元素,如果那頭沒空,直接重新分配空間,空間按每次*3增長直至足夠。

             

            這樣,push_back 的性能與 std::vector 以及 std::deque 的粗略比較如下(圖中的單位寫錯了,全是秒):

            image

            image

            image

            image

             

            insert(begin(), i) 比較:

            image

            image

            (vector 參與這項比較果然是不公平的,呵呵)

            image

            image

             

            insert 到 begin + size() / 2 處:

            image

            image

             

            resize 至固定大小,然后用 iterator 遍歷賦值:

            image

            image

            image

            image

            (今天回家了。以上測試都在家里的機器上做的,配置: AMD SP2500+ 1.4GHz,512MB RAM。)

             

            這樣的結(jié)果還算滿意的。不知道 vector 為什么能保持 push_back 如此高效~

            還有個挺奇怪的現(xiàn)象,使用 deque 的時候,如果數(shù)據(jù)量到百萬,臨退出前有好長一段時間要等待,難道是 deque 在做某些析構(gòu)動作?

            再呢。。貌似 deque 的 push_front 并沒有 vector 的 push_back 神么、、

             

            嗯……我的本意不是為了著重性能,而是嘗試些有著那么一套接口的東西出來,同時也給自己用。現(xiàn)在來比性能只是為了論證一下實用程度如何,如此而已。

            具體實現(xiàn)代碼就不貼了,基本接口和上上篇里沒多少變化。等以后這方面的東西做完了再一起拿出來。

            posted on 2009-10-01 20:17 溪流 閱讀(340) 評論(1)  編輯 收藏 引用 所屬分類: C++

            評論:
            # re: 昨天傻掉了,是策略沒搞好 2009-10-12 18:38 | 陳梓瀚(vczh)
            你可以看看Delphi的TObjectList的實現(xiàn)。  回復  更多評論
              
            97超级碰碰碰久久久久| 久久夜色精品国产噜噜麻豆 | 91精品婷婷国产综合久久| 久久www免费人成精品香蕉| 无码人妻久久久一区二区三区| 91精品国产色综合久久| 久久99毛片免费观看不卡 | 久久只有这精品99| 狠狠色丁香婷婷综合久久来来去 | 亚洲国产天堂久久综合| 久久精品一区二区| 色8激情欧美成人久久综合电| 中文字幕一区二区三区久久网站| 久久九九久精品国产| 国产成人AV综合久久| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久久久亚洲AV成人网人人网站| 国产亚洲色婷婷久久99精品91 | 国产亚洲精久久久久久无码| 久久精品国产亚洲AV香蕉| 久久久久久a亚洲欧洲aⅴ| 久久99精品国产一区二区三区| 亚洲Av无码国产情品久久| 99久久亚洲综合精品成人| 亚洲欧美成人综合久久久| 欧洲性大片xxxxx久久久| 久久国产精品免费一区| 国产精品一久久香蕉产线看| 久久天天躁狠狠躁夜夜2020一| 久久久久久久综合综合狠狠| 久久精品九九亚洲精品天堂| 久久久久亚洲精品无码蜜桃| 精品永久久福利一区二区| 色综合久久夜色精品国产| 久久久久综合中文字幕| 久久久亚洲欧洲日产国码是AV| 久久久国产精品| 久久国产成人午夜aⅴ影院 | 亚洲av成人无码久久精品 | 中文字幕久久精品无码| 精品久久人妻av中文字幕|