U.Mutlu wrote on 06/22/2018 02:02 PM:
Jonathan Wakely wrote on 06/22/2018 01:27 PM:
On Fri, 22 Jun 2018 at 11:35, U.Mutlu wrote:
Jonathan Wakely wrote on 06/22/2018 11:42 AM:
On Fri, 22 Jun 2018 at 07:32, U.Mutlu wrote:
(The manual version has of course the disadvantage that user has to
define an
additional variable and because of that, put the code in its own scope...)
You don't have to change the scope:
for (size_t i = 1, vec_sz = vec.size(); i < vec_sz; ++i)
Yes, I know that, but it lacks the "const" attribute.
Does it matter? The compiler can still see it doesn't change.
Yes, true, compiler can optimize it.
Here's another, more general C++ solution for defining any type of variables,
also additional variables to be used only inside the for-loop:
struct forVars { const size_t sz; size_t i; forVars(const size_t Asz, const
size_t Astart = 0) noexcept : sz(Asz), i(Astart) {} };
for (forVars S(vec.size()); S.i < S.sz; ++S.i) // S.sz is const
Fix:
for (forVars S(vec.size(), 1); S.i < S.sz; ++S.i) // S.sz is const
...
:-)
Maybe a little bit overkill for this simple example... :-)