溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

c++中vector模擬實現(xiàn)的示例分析

發(fā)布時間:2021-04-12 14:00:02 來源:億速云 閱讀:159 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細講解有關(guān)c++中vector模擬實現(xiàn)的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

一、vector是什么?

vector是表示可變大小數(shù)組的序列容器,它也采用連續(xù)存儲空間來存儲元素,因此可以采用下標對vector的元素進行訪問,它的大小是動態(tài)改變的,vector使用動態(tài)分配數(shù)組來存儲它的元素;

二、容器特性

1.順序序列

順序容器中的元素按照嚴格的線性順序排序??梢酝ㄟ^元素在序列中的位置訪問對應(yīng)的元素;

2.動態(tài)數(shù)組

支持對序列中的任意元素進行快速直接訪問,甚至可以通過指針進行該操作。操供了在序列末尾相對快速地添加/刪除元素的操作;

3.能夠感知內(nèi)存分配器的

容器使用一個內(nèi)存分配器對象來動態(tài)地處理它的存儲需求;

三、vector的模擬實現(xiàn)

定義一個類:

template<class T>
class Vector
{
    T* _start; //首元素地址
    T* _finish; //最后一個元素地址的下一個地址
    T* _endOfStorage; //空間的尾地址
public:
//成員函數(shù)
};

構(gòu)造函數(shù)

Vector()
    :_start(nullptr)
    , _finish(nullptr)
    , _endOfStorage(nullptr)
{}

Vector(size_t n, const T& value = T())
    :_start(nullptr)
    , _finish(nullptr)
    , _endOfStorage(nullptr)
{
    reserve(n);
    while (n--)
    {
        push_back(value);
    }
}
Vector(InputInterator first, InputInterator last)
        :_start(nullptr)
        , _finish(nullptr)
        , _endOfStorage(nullptr)
    {
        while (first != last)
        {
            pushBack(*first);
            ++first;
        }
    }

數(shù)據(jù)大小、空間大小

size_t size() const
{
    return _finish - _start;
}

size_t capacity() const
{
    return _endOfStorage - _start;
}

尾插

void pushBack(const T& value)
    {
        if (_finish == _endOfStorage)
        {
            size_t newC = _endOfStorage == nullptr ? 1 : 2 * capacity();
            reverse(value);
        }
        *_finish = value;   
        ++_finish;
    }

擴容

有資源進行拷貝時,使用深拷貝;類型為自定義類型時,發(fā)生淺拷貝,調(diào)用自定義類型析構(gòu)函數(shù),釋放資源,導(dǎo)致資源二次釋放,所以自定義類型的拷貝有資源時進行深拷貝;

深拷貝與淺拷貝的區(qū)別及應(yīng)用

void reserve(size_t n)
{
if (n &gt; capacity())
{
size_t sz = size();
T* arr = new T[n];
if (_start)
{
memcpy(arr, _start, sizeof(T) * sz);
delete[] _start;
}
//update
_start = arr;
_finish = _start + sz;
_endOfStorage = _start + n;
}
}

改變數(shù)據(jù)大小

void resize(size_t n, const T& val = T())
    {
        if (n > capacity())
        {
            reserve(n);
        }
        else if (n > size())
        {
            while (_finish != _start + n)
            {
                *_finish = val;
                _finish++;
            }
        }
            _finish = _start + n;
    }

位置插入值

void insert(iterator pos, const T& val)
    {
        size_t sz = pos - _start;
        //檢查位置
        if (pos >= _start && pos <= _finish)
        {
            //檢查容量
            if (_finish == _endOfStoage)
            {
                size_t n = _endOfStorage == nullptr ? 1 : 2 * capacity();               
                reserve(n);
                //更新迭代器
                pos = _start + sz;
            }
            //移動元素
            iterator end_u = _finish;
            while (end_u != pos)
            {
                *end = *(end_u - 1);
                --end_u();
            }
            //插入元素
            *pos = val;
            //更新位置
            ++_finish;
        }
    }

刪除數(shù)據(jù)

iterator erase(iterator pos)
    {
        //檢查位置
        if (pos < _finish && pos >= _start)
        {
            //移動元素
            iterator start = pos + 1;
            while (start!=_finish)
            {
                *(start - 1) = *start;
                start++;
            }
            //更新
            --_finish;
        }
        return pos;
    }
    //返回刪除數(shù)據(jù)的下一個元素的位置

operator[] 重載

T& operator[](size_t pos)
    {
        if (pos >= 0 && pos < size())
            return _start[pos];
    }

operator= 重載

Vector<T>& operator=(const Vector<T>& v)
    {
        if (this != &v)
        {
            delete[]_start;
            size_t n = v.capacity();
            _start = new T[n];
            for (size_t i = 0; i < v.capacity(); ++i)
            {
                _start[i] = v._start[i];
            }
            _finish = _start + v.size();
            _finish = _start + n;
        }
        return *this;
    }

迭代器

//vector迭代器:T*
typedef T* iterator;
typedef const T* const_iterator;

iterator begin()
{
    return _start;
}

iterator end()
{
    return _finish;
}

const_iterator begin() const
{
    return _start;
}

const_iterator end() const
{
    return _finish;
}

析構(gòu)函數(shù)

~Vector()
{
    if (_start)
    {
        delete[] _start;
        _start = _finish = _endOfStorage = nullptr;
    }
}

關(guān)于“c++中vector模擬實現(xiàn)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI