我作了雙向擴充實現(xiàn)。昨天的方案是:
先判斷插入的元素靠前還是靠后,靠哪邊就準備往哪邊挪舊元素,然后檢查那頭有沒有空,沒空換另一頭,要是都沒空但兩頭加起來卻有空,那就重新調(diào)整位置,最后才重新分配空間。
我原以為考慮得好周到,可是實現(xiàn)起來卻傻了眼。往末尾插入10萬數(shù)據(jù),有9萬多次發(fā)生移動元素,不慢才怪。
調(diào)整了下,變成:
先判斷考前還是靠后,靠哪邊就往哪邊挪舊元素,如果那頭沒空,直接重新分配空間,空間按每次*3增長直至足夠。
這樣,push_back 的性能與 std::vector 以及 std::deque 的粗略比較如下(圖中的單位寫錯了,全是秒):
insert(begin(), i) 比較:
(vector 參與這項比較果然是不公平的,呵呵)
insert 到 begin + size() / 2 處:
resize 至固定大小,然后用 iterator 遍歷賦值:
(今天回家了。以上測試都在家里的機器上做的,配置: 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++