Revision [14587]

This is an old revision of KeyPgFornext made by AgAmemnus on 2010-05-18 13:28:43.



Control flow statement for looping

For iterator [ KeyPgAs as DataType datatype ] = startvalue To endvalue [ Step stepvalue ]
[ statement block ]
Next [ iterator ]

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

A For...Next loop initializes iterator to startvalue, then executes the statement block's, incrementing iterator by stepvalue until it reaches endvalue. If stepvalue is not explicitly given it will set to 1.
The values of stepvalue and endvalue are stored internally immediately following execution of the for statement and thus neither can be changed inside the for loop. (the variables that define them can be changed, but changing those variables inside the for loop will not affect its execution. See examples)

The iterator may be defined having the same scope as the For statement by using the KeyPgAs as DataType datatype syntax. With this syntax, iterator is created and destroyed within the For...Next scope. See dialect differences below.
The For statement causes the execution of the statements in the statement block until iterator compares greater than endvalue. iterator will be incremented the amount of stepvalue following each execution of the statement block. If an increment is not given, iterator will be implicitly incremented by 1.
If endvalue is less than startvalue then a negative stepvalue must be specified or the statement block will not execute at all, since startvalue compares greater than endvalue.
If an KeyPgExit Exit For statement is encountered inside the statement block, the loop is terminated, and execution resumes immediately following the enclosing Next statement. If a KeyPgContinue Continue For statement is encountered, the rest of the statement block is skipped and execution resumes at the FOR statement.
Like all control flow statements, the For statement can be nested, that is, it can be used in a statement block of another For statement.
note: When a negative stepvalue is specified, the For statement loops until iterator compares less than end_value.
For, Next, and Step are operators that can be overloaded inside user defined types. See KeyPgOpFor Operator For, KeyPgOpNext Operator Next, KeyPgOpStep Operator Step

Dim i As Single
Print "counting from 3 to 0, with a step of -0.5"
For i = 3 To 0 Step -0.5
    Print "i is " & i
Next i

Dialect Differences:
Differences from QB:
See also:
Back to Control Flow
Valid XHTML :: Valid CSS: :: Powered by WikkaWiki phatcode