【C++】自定义实现 vector 模板类(code c++)


程序代码

自定义实现 vector 模板类 code c++

#include <iostream>
#include <vector>
using namespace std;

class A {
public :
    A() = delete;
    A(int x) : x(x) {}
    friend ostream &operator<<(ostream &out, const A &);
private:
    int x;
};

ostream &operator<<(ostream &out, const A &a) {
    out << "Class A : " << a.x;
    return out;
}

namespace haizei {
template<typename T>
class vector {
public :
    vector(int n = 10); // 不可用 new, 因为可能没有默认构造
    vector(const vector<T> &v); // 原地构造, 因为可能没有赋值运算符
    vector(vector<T> &&v);
    
    T &operator[](int ind);
    const T &operator[](int ind) const; 
    int size() const;
    void push_back(const T &);
    void push_back(T &&);
    
    ~vector(); 
private:
    int __capacity, __size;
    T *data;
};

template<typename T>
vector<T>::vector(int n) : __capacity(n), __size(0), data(nullptr) {
    data = (T *)malloc(sizeof(T) * __capacity);
} 
template<typename T>
vector<T>::vector(const vector<T> &v) : __capacity(__capacity), __size(v.__size) {
    data = (T *)malloc(sizeof(T) * __capacity);
    for (int i = 0; i < __size; ++i) {
        new(data + i) T(v.data[i]);
    }
    return ;
}
template<typename T>
vector<T>::vector(vector<T> &&v) : __capacity(v.capacity), __size(v.__size), data(v.data) {
    v.data = nullptr;
    v.__capacity = 0;
    v.__size = 0;
}
template<typename T>
T &vector<T>::operator[](int ind) {
    return data[ind];
}
template<typename T>
const T &vector<T>::operator[](int ind) const {
    return data[ind];
}
template<typename T>
int vector<T>::size() const { return __size; }
template<typename T>
void vector<T>::push_back(const T &d) {
    new(data + __size) T(d); // 原地构造
    __size += 1;
    return ;
}
template<typename T>
void vector<T>::push_back(T &&d) {
    new(data + __size) T(move(d));
    __size += 1;
    return ; 
}
template<typename T>
vector<T>::~vector() {
    if (data) free(data);
    __size = 0;
    __capacity = 0;
    return ;
}

} // end of haizei

ostream &operator<<(ostream &out, const vector<A> &v) {
    for (int i = 0; i < v.size(); ++i) {
        cout << v[i] << " ";
    }
    return out;
}
template<typename T>
ostream &operator<<(ostream &out, const haizei::vector<T> &v) {
    for (int i = 0; i < v.size(); ++i) {
        cout << v[i] << " ";
    }
    return out;
}

int main() {
    A a = 1;
    cout << a << endl;
    vector<A> v1;
    cout << v1.size() << endl;
    v1.push_back(123);
    v1.push_back(456);
    v1.push_back(789);
    haizei::vector<A> v2;
    cout << v2.size() << endl;
    v2.push_back(123);
    v2.push_back(456);
    v2.push_back(789);
    cout << v1 << endl;
    cout << v2 << endl;
    return 0;
}

运行结果

Class A : 1
0
0
Class A : 123 Class A : 456 Class A : 789 
Class A : 123 Class A : 456 Class A : 789 

结论

代码示例,有问题留言。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

idiot5liev

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值