梁梦笙 2021-08-20 00:18 采纳率: 100%
浏览 41
已结题

vector容器只初始化10个数,容量为什么是13,不是10?


#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<string>
#include<vector>
using namespace std;

void printvec(vector<int>& v)
{
    for (vector<int>::iterator i = v.begin(); i != v.end(); i++)
    {
        cout << *i << "  ";
    }
    cout << endl;
}
void test3()//vector容量与大小
{
vector<int> v1;
    for (int i = 0; i < 10; i++)
    {
        v1.push_back(i);
    }
    if (v1.empty() == true)
    {
        cout << "V1为空" << endl;
    }
    else
    {
        cout << "V1不为空" << endl;
        cout << "V1容量为:" << v1.capacity() << endl;;
        cout << "V1数据个数:" << v1.size() << endl;
        printvec(v1);
        }
}
int main()
{
    test3();
    return 0;
}

img

  • 写回答

2条回答 默认 最新

  • 阿肥哥哥_12138 2021-08-20 10:14
    关注

    当vector添加一个元素时,为了满足连续存放这个特性,都需要重新分配空间、拷贝元素、撤销旧空间,这样性能难以接受。因此STL实现者在对vector进行内存分配时,其实际分配的容量要比当前所需的空间多一些。就是说,vector容器预留了一些额外的存储区,用于存放新添加的元素,这样就不必为每个新元素重新分配整个容器的内存空间。

    以上是我昨天刚看到的内容,大概说的就是你存十个数,但是为了方便下次储存,他会多分配一点空间。因为vector是创建一个更大的空间然后把原来空间的数据复制过去,在释放原来的空间,这段过程就很麻烦,为了方便添加,所以多分配了一点

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月30日
  • 已采纳回答 8月22日
  • 创建了问题 8月20日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分