Dizem que eu tenho algo parecido com isto:
void myFunk(std::vector<T>& v, std::vector<T>::iterator first, std::vector<T>::iterator last) {
while (first != last) {
if ((*first) > (*last)) {
T someT;
v.push_back(someT);
}
first++;
}
}
int main(){
std::vector<T> foo = {some, T, values};
myFunky(foo, foo.begin(), foo.end())
return 0;
}
Isso levaria a um loop infinito, ou iria acabar depois foo.size()
iterações? Em outras palavras, seria o last
o iterador de ser atualizado como foo
cresceu, ou seria manter o valor dado a chamada de função?
Eu estou supondo que last
iria mudar, já que é um ponteiro para uma posição, mas gostaria de alguma confirmação.