2:vector

STL顺序容器vector相比数组,可以动态扩容,具体见下图Vector

在STL中vector是一种模板库,部分实现如下:

template<typename T> class MyVector:public Container<T>
{
public:
    MyVector();
    ~MyVector();
    void re_capacity(size_t s);  //重新扩容
    void push(const T& v);
    void pop();
    const T& begin();
    const T& end();
    size_t size();
    const T& operator[] (size_t i);  //下标访问操作符
private:
    size_t _size ;    //容器内数据大小
    size_t _cap ;     //已分配容量大小
    T* buf ;       //首地址,用于创建内存

};
template <typename T> MyVector<T>::MyVector()
{
    _size = 0;
    _cap = _step;
    buf = 0;
    re_capacity(_cap);
}
template<typename T> MyVector<T>::~MyVector()
{
    free(buf);
}
template<typename T> void MyVector<T>::re_capacity(size_t s)
{
    if (!buf)
        buf = (T*)malloc(sizeof(T)*s);
    else
        buf = (T*)realloc(buf, sizeof(T)*s);
}
template<typename T> void MyVector<T>::push(const T& v)
{
    if (_size >= _cap)
        re_capacity(_cap += _step);
    buf[_size++] = v;
}
template<typename T> void MyVector<T>::pop()
{
    if (_size)
        _size--;
}
template<typename T> const T& MyVector<T>::begin()
{
    return buf[0];
}
template<typename T> const T& MyVector<T>::end()
{
    if (_size)
        return buf[_size - 1];
}
template<typename T> size_t MyVector<T>::size()
{
    return _size;
}
template<typename T> const T& MyVector<T>::operator[] (size_t i)
{
    if (i >= 0 && i < _size)
        return buf[i];
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值