STL vector (一)——扩容原理与内存分配与释放

 vector 常被称为“容器”,习惯将之理解为动态数组。它表示对象的集合,其中所有对象都相同,每个对象都对应一个索引,索引用来访问对象。作为动态数组,vector 有一个指针指向一片连续的内存空间。但是,这个内存空间肯定不是无限大的,当内存装不下数据时,系统会自动申请一片更大的空间,把原来的数据拷贝过去,释放原来的内存空间。具体来看。

      1、内存分配

      vector 里面有 2 个成员函数——size() 和 capacity(),capacity()返回 vector 当前实际申请的空间大小,这部分空间称为缓冲区。而 size() 返回的是当前对象缓冲区元素的个数。显然,capacity() 是大于等于 size()的,当 size() 和capacity() 相等时,如果继续使用 push_back() 添加元素,vector 就会扩容。

      先看一段程序。

int main()
{
	vector<int> v1;
	for (int i = 1; i < 12; i++)
	{
		v1.push_back(i);
		cout << v1.capacity() << "    " << v1.size() << endl;
	}

}

看看运行结果:



      我们可以看到,起初,vec

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值