This feels like a newbie issue, but I can’t seem to figure it out. I want to iterate over the items in a std::vector. Currently I use this loop:
for (unsigned int i = 0; i < buffer.size(); i++) {
myclass* var = buffer.at(i);
[...]
}
However, I realised that I actually want to iterate over it in the opposite order: starting at the end and working my way to 0. So I tried using this iterator:
for (unsigned int i = buffer.size()-1; i >= 0; i--) {
myclass* var = buffer.at(i);
[...]
}
But by simply replacing the old line with the new (and of course, recompiling), then it goes from running properly and iterating over the code, it instead causes the program to crash the first time it hits this line, with this error:
http://i43.tinypic.com/20sinlw.png
Followed by a “[Program] has stopped working” dialog box.
The program also returns exit code 3, according to Code::Blocks, which (if this article is to be believed) means ERROR_PATH_NOT_FOUND: The system cannot find the file specified.
Any advice? Am I just missing something in my for loop that’s maybe causing some sort of memory issue? Is the return code of 3, or the article, misleading, and it doesn’t actually mean “path not found”?
When
i == 0(i.e. what should be the last iteration), the decrementi--causesito wrap around to the largest possible value for anunsigned int. Thus, the conditioni >= 0still holds, even though you’d like the loop to stop.To fix this, you can try something like this, which maintains the original loop logic, but yields a decrementing
i:Alternatively, since
std::vectorhasrbeginandrendmethods defined, you can use iterators:(There might be small syntactic errors – I don’t have a compiler handy)