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

統計

  • 隨筆 - 50
  • 文章 - 42
  • 評論 - 147
  • 引用 - 0

留言簿(6)

隨筆分類

文章分類

Link

搜索

  •  

積分與排名

  • 積分 - 167776
  • 排名 - 159

最新評論

閱讀排行榜

評論排行榜

簡版 容器vector 實現

vector為我們提供了可伸縮的順序存儲容器,在順序和隨機存儲方面效率很高

實現vector的關鍵在于實現內存分配和對象構造的分離,一般來講我們直接用new來構造對象就經歷了這兩個過程,而實現vector就需要我們先申請請到一片連續的內存區域,然后在需要時在改內存上構造對象。這里用到allocator模板類
該類內部封裝了如下方法:
template<typename elm>
class allocator
{
elm *allocate(size_t n)      //分配n個對象存儲空間
void construct(elm* p,size_t n) //在以p為開始的內存上構造n個對象
void destroy(elm* p) //銷毀對象
void deallocate(elm*p,size_t n) //釋放從p開始的n個對象內存

}
有了這些就足夠了,一下就是簡版Vector實現LyVector
 1#include "stdafx.h"
 2#include "memory"
 3template <typename elmType>
 4class LyVector
 5{
 6private:
 7    elmType* _first;
 8    elmType* _last;
 9    elmType* _end;
10    allocator<elmType> _alc;
11public:
12    typedef typename elmType valueType;
13    LyVector():
14      _first(0),_last(0),_end(0){};
15    bool push_back(const elmType &t)
16    {
17        if (_last==_end)
18        {
19            size_t size=_last-_first;
20
21            size_t capacity=2*size;
22            if (capacity==0)
23            {
24                capacity=2;
25            }

26            //創建新的存儲區域并賦值
27            elmType* newElm=_alc.allocate(capacity);
28            if (newElm==NULL)
29            {
30                return false;
31            }

32            uninitialized_copy(_first,_last,newElm);
33            //刪除就有存儲區
34            for(;_first!=_last;)
35                _alc.destroy(--_last);
36            _alc.deallocate(_first,size);
37            _first=newElm;
38            _last=newElm+size;
39            _end=newElm+capacity;
40        }

41        _alc.construct(_last++,t);
42        return true;
43    }

44    void popBack()
45    {
46        if (size()==0)
47        {
48            _DEBUG_ERROR("No element fount");
49            return;
50        }

51        _alc.destroy(--_last);
52    }

53    
54    size_t size()
55    {
56        return _last-_first;
57    }

58    size_t capacity()
59    {
60        return _end-_first;
61    }

62    
63    elmType* operator[](size_t pos)
64    {
65        if (pos>=size())
66        {
67            _DEBUG_ERROR("out of range");
68            return NULL;
69        }

70        return _first+pos;
71    }

72
73
74    friend ostream& operator<<(ostream &o,const LyVector &im)
75    {
76        for (LyVector::valueType * first=im._first;first!=im._last;first++)
77        {
78            o<<*first<<endl;
79        }

80        return o;
81    }

82}
;

從實現看來,我覺得在使用vector,有以下幾點注意:
1. 最好為所存儲對象實現拷貝構造函數,不然在重新分配存儲空間時可能會產生內存訪問違規問題,原因是對象在存入vector和在vecotr重新構造是都會調用拷貝構造函數
2. 對象存入是會在制定位置產生新的對象,不必擔心原對象生存期

posted on 2009-08-12 15:46 pear_li 閱讀(2517) 評論(0)  編輯 收藏 引用 所屬分類: C++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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一区二区三区久久| 欧美成人免费视频| 久久国产精品黑丝| 免费精品99久久国产综合精品| 欧美黄在线观看| 亚洲在线一区二区三区| 亚洲欧美日韩视频一区| 免费欧美日韩| 国产精品一区二区三区四区 | 国产精品久久二区| 精品99一区二区| 在线一区欧美| 欧美国产一区二区| 欧美精品激情在线| 亚洲国产精品久久久久婷婷884| 亚洲欧美日韩爽爽影院| 91久久嫩草影院一区二区| 午夜天堂精品久久久久| 亚洲国产另类精品专区 | 亚洲激情二区| 欧美亚一区二区| 亚洲精品国产欧美| 欧美电影在线| 国产精品国产一区二区| 久久精品91| 午夜精品福利视频| 亚洲国产精品尤物yw在线观看| 久久久另类综合| 欧美在线日韩| 国产一区999| 开心色5月久久精品| 久久成人免费日本黄色| 国产亚洲精品自拍| 最新亚洲激情| 精品成人国产在线观看男人呻吟| 亚洲国产日韩一区| 国产日韩精品入口| 久久亚洲一区二区| 久久精品在线| 亚洲人成网站在线观看播放| 亚洲国产精品电影| 国产一区二区三区久久精品| 日韩午夜在线视频| 国产精品自拍在线| 亚洲欧洲在线视频| 一区一区视频| 欧美在线日韩| 翔田千里一区二区| 欧美一区二区私人影院日本| 精品va天堂亚洲国产| 亚洲一区二区精品在线| 99精品视频免费全部在线| 一区二区三区国产在线观看| 国产麻豆精品久久一二三| 亚洲精品日韩在线观看| 国产精品免费在线| 久久嫩草精品久久久精品| 国产精品大片| 日韩午夜一区| 亚洲免费观看高清在线观看| 一区二区三区国产在线| 99re8这里有精品热视频免费| 麻豆精品精华液| 久久最新视频| 在线成人www免费观看视频| 亚洲国产精品一区二区久| 亚洲二区精品| 久久婷婷麻豆| 亚洲在线视频| 免费观看成人鲁鲁鲁鲁鲁视频| 久久久综合网站| 国内外成人免费激情在线视频网站 | 日韩一区二区精品葵司在线| 久久亚洲精品一区二区| 欧美+亚洲+精品+三区| 欧美日韩爆操| 久久久久久久91| 欧美日韩不卡| 一本色道久久综合狠狠躁的推荐| 亚洲一区二区不卡免费| 久久欧美肥婆一二区| 欧美二区不卡| 亚洲六月丁香色婷婷综合久久| 欧美激情综合色综合啪啪| 亚洲黄色在线视频| 中文在线不卡视频| 久久视频在线视频| 欧美sm重口味系列视频在线观看| 在线观看成人av| 欧美交受高潮1| 亚洲一区二区三区欧美| 老司机67194精品线观看| 亚洲黄色在线看| 欧美日韩综合精品| 亚洲精品小视频| 午夜精品短视频| 亚洲国产第一页| 欧美午夜国产| 久久美女性网| 亚洲美女中文字幕| 久久精品一二三区| 91久久精品一区二区别| 欧美三级视频| 久久亚洲春色中文字幕久久久| 亚洲日本欧美天堂| 亚洲人成在线播放| 国产精品女人久久久久久| 欧美一区二区日韩一区二区| 六月婷婷一区| 亚洲欧美日韩中文视频| 在线观看视频一区二区欧美日韩| 欧美另类久久久品| 亚洲开发第一视频在线播放| 欧美伊人久久久久久久久影院| 国产欧美日韩一区| 欧美激情精品久久久久久蜜臀 | 久久免费一区| 在线视频欧美日韩精品| 黑人极品videos精品欧美裸| 欧美中文在线免费| 日韩视频中文字幕| 欧美.www| 久久美女性网| 午夜精品视频在线观看一区二区 | 亚洲国产精品嫩草影院| 亚洲欧美春色| 亚洲免费成人av| 伊人精品视频| 国产亚洲在线| 国产乱码精品一区二区三区忘忧草| 蘑菇福利视频一区播放| 久久成人一区二区| 午夜精品美女久久久久av福利| 亚洲欧洲一区二区天堂久久| 欧美成人午夜视频| 巨乳诱惑日韩免费av| 久久精品免费观看| 久久av一区| 午夜亚洲福利| 亚洲欧美日韩中文播放| 亚洲综合视频网| 亚洲影院免费观看| 亚洲欧美久久久| 亚洲一区二区精品| 一区二区三区欧美在线| 亚洲精品网站在线播放gif| 在线观看日韩一区| 亚洲国产精品成人精品| 亚洲第一中文字幕| 欧美区一区二| 欧美日韩亚洲另类| 欧美在线播放视频| 欧美与黑人午夜性猛交久久久| 亚洲欧美在线另类| 欧美影视一区| 久久九九国产| 免费成人黄色| 欧美日韩成人精品| 国产精品进线69影院| 国产精品一区二区三区免费观看| 国产精品免费一区二区三区观看| 国产精品综合视频| 国产一区二区三区高清在线观看 | 欧美日韩国产一级片| 欧美日韩第一区日日骚| 欧美日韩综合久久| 国产伦理精品不卡| 在线精品观看| 在线一区二区三区做爰视频网站| 亚洲欧美日本在线| 久久免费视频在线| 亚洲高清123| 久久夜色精品国产亚洲aⅴ| 美女日韩欧美| 亚洲精品日韩在线| 香蕉成人久久| 亚洲影视综合| 久久综合伊人77777| 久久国产精品电影| 欧美mv日韩mv亚洲| 国产精品日韩一区二区| 欧美午夜免费| 精品二区视频| 在线视频你懂得一区二区三区| 久久不射电影网| 91久久精品国产91性色tv| 一本久久青青| 久久夜色撩人精品| 国产精品午夜国产小视频| 最新69国产成人精品视频免费| 亚洲自拍都市欧美小说| 欧美韩日一区二区| 午夜精品久久久久| 欧美精品久久久久久久久老牛影院| 国产毛片一区二区| 一本不卡影院| 亚洲欧美日韩在线| 亚洲黄色三级| 久久久久久夜精品精品免费| 蜜桃久久av一区|