C++ 从零开始实现一个简化版 `std::vector`:深入内存管理

哈喽,各位好!今天我们来一起手撸一个简化版的 std::vector,重点放在内存管理上,保证让你彻底理解 C++ 里面的动态数组是怎么回事儿。

啥是 std::vector

简单来说,std::vector 就是一个可以自动增长的数组。你不用一开始就确定它的大小,可以随时往里面添加元素,它会自动帮你分配和释放内存。这玩意儿在 C++ 里简直是神器,用得不要太频繁。

为啥要自己实现?

直接用 std::vector 不香吗?香!但是,想要真正理解它的工作原理,特别是内存管理那一块,最好的办法就是自己动手实现一个简化版。这样你才能知道 std::vector 背后都做了些什么,以后遇到内存相关的问题也能更快地定位。

我们简化版的目标

  • 动态增长: 可以像 std::vector 一样,动态地添加元素。
  • 基本操作: 实现 push_back(添加元素到末尾)、size(获取元素个数)、capacity(获取容量)、operator[](下标访问)等基本操作。
  • 内存管理: 重点关注内存的分配、释放和重新分配。
  • 异常安全:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值