FOR iterator = startvalue TO endvalue [ STEP stepvalue ]
   [ sentences ]
 NEXT [ iterator ]


  • iterator: a variable identifier that is used to iterate from an initial value to an end value.
  • datatype: If specified, the variable iterator will automatically be declared with the type datatype.
  • startvalue: an expression that denotes the starting value of the iterator.
  • endvalue: an expression used to compare with the value of the iterator.
  • stepvalue: an expression that is added to the iterator after every iteration.


A For...Next loop initializes iterator to startvalue, then executes the sentences, incrementing iterator by stepvalue until it reaches or exceeds endvalue. If stepvalue is not explicitly given it will set to 1.


FOR i = 1 TO 10: PRINT i: NEXT

Differences From Sinclair Basic

  • The variable name after the NEXT statement is not required.

  • Note that variable types can cause issues with ZX Basic For...Next Loops. If the upper limit of the iterator exceeds the upper limit of the variable type, the loop may not complete. For example:

DIM i as UByte

FOR i = 1 to 300
    PRINT i

Clearly, since the largest value a byte can hold is 255, it's not possible for i in the above example to exceed 300. The variable will "wrap around" to 0 and as a result, the loop will not ever terminate. This can happen in much more subtle ways when STEP is used. There has to be "room" within the variable type for the iterator to exceed the terminator when it is being incremented by "STEP" amounts.

See Also