I have a function that contains two for loops, and I’m using a variable called count as the counter. I’ve chosen to recycle the name as the the first loop will finish it’s execution completely before the second one begins, so there is no chance of the counters interfering with each other. The G++ compiler has taken exception to this via the following warning:
error: name lookup of ‘count’ changed for ISO ‘for’ scoping
note: (if you use ‘-fpermissive’ G++ will accept your code)
Is variable recycling considered bad practice in professional software development, or is it a situational concern, and what other implications have I missed here?
Are you doing this?
I doubt
gccwould like that, as the secondcountisn’t in scope. I think it only applies to the firstforloop, butgcchas options to accept poor code. If you either make the secondint countor move the first to the outer scope,gccshould be happy.This depends on the circumstances, but I generally don’t reuse variables. The name of the variable should reflect its purpose, and switching part way through a function can be confusing. Declare what you need, let the compiler take care of the optimizations.