vector模拟实现的注意事项

文章讨论了在C++中模拟实现vector类模板时应注意的事项,包括使用类模板处理可变类型、深浅拷贝的管理,特别是对于T类型的赋值操作要求,以及如何处理缺省值。此外,还强调了迭代器失效问题,特别是在insert和erase操作后返回新有效的迭代器的重要性。最后,提到了vector构造函数接受通用迭代器的功能,需要使用函数模板来实现。
摘要由CSDN通过智能技术生成

vector模拟实现注意事项

类模板

1.类型和类名

相较于string,vector的类型是可变的,因此在实现时需要用到类模板。注意vector是类名,vector是类型,要实现构造和析构时用类名vector,其余地方要用类型vector。

2.深浅拷贝

由于T的类型未知,因此在实现vector的一些功能(如拷贝)时要注意深拷贝和浅拷贝的问题。如果用memcpy那么就是浅拷贝,用赋值就是深拷贝。(T类型应该保证好赋值重载符合需求)

3.缺省值

要将类型为T的参数写成缺省参数时,应写为vector(size_t n=0,const T& x = T() ),c++对内置类型做了处理,让内置类型也支持虚拟对象的写法,如int i = int()。

迭代器失效问题

当我们在外部定义了一个迭代器pos,调用函数insert在pos位置插入数据,若此时vector扩容(重新申请新的空间,释放旧空间),pos将失效(变成野指针)。因此实现insert,erase等可能引发迭代器失效的函数时,应该用返回值返回新的有效迭代器。

通用的迭代器

vector (InputIterator first, InputIterator last)

该构造函数的迭代器并非只支持vector容器的迭代器,而是支持所有容器的迭代器,因此该函数需要用函数模板

template<typename InputIterator>
vector (InputIterator first, InputIterator last)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值