vector :: push_back vs vector :: operator []

时间:2012-06-13 01:23:32

标签: c++ stl vector operator-keyword push-back

以下c++计划,

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

int main()
{
     vector<int> numbers;

    numbers.push_back(2);
    numbers.push_back(10);
    numbers.push_back(5);
    numbers.push_back(3);
    numbers.push_back(7);

    numbers[3] = 8;
    numbers[5] = 11;

    for(int i=0; i<numbers.size(); ++i)
    {
            cout<<" "<<numbers[i];
    }
}    

ideone上查看。

此处,numbers[3]正在运作,numbers[5] 看起来,vector :: operator []不会像vector :: push_back那样增加向量的大小 所以,这是这两者之间的唯一区别还是其他什么

2 个答案:

答案 0 :(得分:11)

std::vector::operator[]:“访问指定元素”

std::vector::push_back:“将元素添加到结尾”

我在查看c ++引用时非常惊讶。你应该试一试。

答案 1 :(得分:7)

push_back在背面创建一个具有指定值的新元素。 operator[]要求元素在那里;它只是访问它。 [5]不起作用的原因是因为你有5个元素,所以你的索引范围从0到4。

通常,在添加新元素时,push_back优先于resize,后跟operator[]。但是,只有一个可用于读取,并且还需要operator[]来维护正常的数组语法。