以下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那样增加向量的大小
所以,这是这两者之间的唯一区别还是其他什么?
答案 0 :(得分:11)
答案 1 :(得分:7)
push_back
在背面创建一个具有指定值的新元素。 operator[]
要求元素在那里;它只是访问它。 [5]
不起作用的原因是因为你有5个元素,所以你的索引范围从0到4。
通常,在添加新元素时,push_back
优先于resize
,后跟operator[]
。但是,只有一个可用于读取,并且还需要operator[]
来维护正常的数组语法。