mirror of
https://github.com/isocpp/CppCoreGuidelines.git
synced 2024-03-22 13:30:58 +08:00
Closes #189.
This commit is contained in:
parent
9c93ba6c5f
commit
9e0b9f435e
@ -7360,6 +7360,7 @@ Statement rules:
|
|||||||
* [ES.78: Always end a non-empty `case` with a `break`](#Res-break)
|
* [ES.78: Always end a non-empty `case` with a `break`](#Res-break)
|
||||||
* [ES.79: ??? `default`](#Res-default)
|
* [ES.79: ??? `default`](#Res-default)
|
||||||
* [ES.85: Make empty statements visible](#Res-empty)
|
* [ES.85: Make empty statements visible](#Res-empty)
|
||||||
|
* [ES.86: Avoid modifying loop control variables inside the body of raw for-loops](#Res-loop-counter)
|
||||||
|
|
||||||
Arithmetic rules:
|
Arithmetic rules:
|
||||||
|
|
||||||
@ -8611,6 +8612,31 @@ Readability.
|
|||||||
|
|
||||||
Flag empty statements that are not blocks and doesn't "contain" comments.
|
Flag empty statements that are not blocks and doesn't "contain" comments.
|
||||||
|
|
||||||
|
|
||||||
|
### <a name="Res-loop-counter"></a> ES.86: Avoid modifying loop control variables inside the body of raw for-loops
|
||||||
|
|
||||||
|
##### Reason
|
||||||
|
|
||||||
|
The loop control up front should enable correct reasoning about what is happening inside the loop. Modifying loop counters in both the iteration-expression and inside the body of the loop is a perennial psource of suprises and bugs.
|
||||||
|
|
||||||
|
##### Example
|
||||||
|
|
||||||
|
for (int i=0; i<10; ++i) {
|
||||||
|
// no updates to i -- ok
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i=0; i<10; ++i) {
|
||||||
|
//
|
||||||
|
if (/* something */) ++i; // BAD
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
##### Enforcement
|
||||||
|
|
||||||
|
Flag variables that are potentially updated (have a non-const use) in both the loop control iteration-expression and the loop body.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## ES.expr: Expressions
|
## ES.expr: Expressions
|
||||||
|
|
||||||
Expressions manipulate values.
|
Expressions manipulate values.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user