All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sonar.l10n.java.rules.java.S127.html Maven / Gradle / Ivy

The newest version!

Why is this an issue?

A for loop termination condition should test the loop counter against an invariant value that does not change during the execution of the loop. Invariant termination conditions make the program logic easier to understand and maintain.

This rule tracks three types of non-invariant termination conditions:

  • When the loop counters are updated in the body of the for loop
  • When the termination condition depends on a method call
  • When the termination condition depends on an object property since such properties could change during the execution of the loop.

How to fix it

Code examples

Noncompliant code example

Make the termination condition invariant by using a constant or a local variable instead of an expression that could change during the execution of the loop.

for (int i = 0; i < foo(); i++) { // Noncompliant, "foo()" is not an invariant
  // ...
}

Compliant solution

int end = foo();
for (int i = 0; i < end; i++) { // Compliant, "end" does not change during loop execution
  // ...
}

Noncompliant code example

If this is impossible and the counter variable must be updated in the loop’s body, use a while or do while loop instead of a for loop.

for (int i = 0; i < 10; i++) {
  // ...
  if (condition) i++; // Noncompliant, i is updated from within body
  // ...
}

Compliant solution

int i = 0;
while (i++ < 10) { // Compliant
  // ...
  if (condition) sum++;
  // ...
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy