vector :: push_back vs vector :: operator []

Eig*_*ght 2 c++ stl vector push-back operator-keyword

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];
    }
}    
Run Code Online (Sandbox Code Playgroud)

ideone上看到它.

在这里numbers[3]工作但是numbers[5].
看起来,vector :: operator []不会像vector :: push_back那样增加向量的大小.
所以,这是这两者之间的唯一区别还是别的什么呢?

Dav*_*vid 11

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

std :: vector :: push_back:"在末尾添加一个元素"

看着c ++引用,我真是太棒了.你应该试试看.


chr*_*ris 7

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

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