Our coding guidelines prefer const_iterator
, because they are a little faster compared to a normal iterator
. It seems like the compiler optimizes the code when you use const_iterator
.
Is this really correct? If yes, what really happens internally that makes const_iterator
faster?.
EDIT: I wrote small test to check const_iterator
vs iterator
and found varying results:
For iterating 10,000 objects const_terator
was taking a few milliseconds (around 16 ms) less. But not always. There were iterations in which both were equal.
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…