可能的复制品:
为什么使用迭代器而不是数组索引
我正在回顾我的 C + + 知识,我偶然发现了迭代器。有一件事我想知道是什么让他们如此特别,我想知道为什么这样:
using namespace std;
vector<int> myIntVector;
vector<int>::iterator myIntVectorIterator;
// Add some elements to myIntVector
myIntVector.push_back(1);
myIntVector.push_back(4);
myIntVector.push_back(8);
for(myIntVectorIterator = myIntVector.begin();
myIntVectorIterator != myIntVector.end();
myIntVectorIterator++)
{
cout<<*myIntVectorIterator<<" ";
//Should output 1 4 8
}
比这更好:
using namespace std;
vector<int> myIntVector;
// Add some elements to myIntVector
myIntVector.push_back(1);
myIntVector.push_back(4);
myIntVector.push_back(8);
for(int y=0; y<myIntVector.size(); y++)
{
cout<<myIntVector[y]<<" ";
//Should output 1 4 8
}
是的,我知道我不应该使用 std 名称空间。我只是从编程网站上拿了这个例子。所以你能告诉我为什么后者更糟糕吗?有什么区别吗?