For Loop
   HOME

TheInfoList



OR:

In
computer science Computer science is the study of computation, automation, and information. Computer science spans theoretical disciplines (such as algorithms, theory of computation, information theory, and automation) to Applied science, practical discipli ...
a for-loop or for loop is a
control flow In computer science, control flow (or flow of control) is the order in which individual statements, instructions or function calls of an imperative program are executed or evaluated. The emphasis on explicit control flow distinguishes an ''imper ...
statement for specifying
iteration Iteration is the repetition of a process in order to generate a (possibly unbounded) sequence of outcomes. Each repetition of the process is a single iteration, and the outcome of each iteration is then the starting point of the next iteration. ...
. Specifically, a for loop functions by running a section of code repeatedly until a certain condition has been satisfied. For-loops have two parts: a header and a body. The header defines the iteration and the body is the code that is executed once per iteration. The header often declares an explicit
loop counter In computer science a for-loop or for loop is a control flow statement for specifying iteration. Specifically, a for loop functions by running a section of code repeatedly until a certain condition has been satisfied. For-loops have two part ...
or loop
variable Variable may refer to: * Variable (computer science), a symbolic name associated with a value and whose associated value may be changed * Variable (mathematics), a symbol that represents a quantity in a mathematical expression, as used in many ...
. This allows the body to know which iteration is being executed. For-loops are typically used when the number of iterations is known before entering the loop. For-loops can be thought of as shorthands for while-loops which increment and test a loop variable. Various keywords are used to indicate the usage of a for loop: descendants of
ALGOL ALGOL (; short for "Algorithmic Language") is a family of imperative computer programming languages originally developed in 1958. ALGOL heavily influenced many other languages and was the standard method for algorithm description used by the ...
use "for", while descendants of Fortran use "do". There are other possibilities, for example
COBOL COBOL (; an acronym for "common business-oriented language") is a compiled English-like computer programming language designed for business use. It is an imperative, procedural and, since 2002, object-oriented language. COBOL is primarily us ...
which uses "PERFORM VARYING". The name ''for-loop'' comes from the word for. For is used as the
keyword Keyword may refer to: Computing * Keyword (Internet search), a word or phrase typically used by bloggers or online content creator to rank a web page on a particular topic * Index term, a term used as a keyword to documents in an information syst ...
in many programming languages to introduce a for-loop. The term in English dates to
ALGOL 58 ALGOL 58, originally named IAL, is one of the family of ALGOL computer programming languages. It was an early compromise design soon superseded by ALGOL 60. According to John Backus The Zurich ACM-GAMM Conference had two principal motives in pro ...
and was popularized in ALGOL 60. It is the direct translation of the earlier German and was used in
Superplan Superplan was a high-level programming language developed between 1949 and 1951 by Heinz Rutishauser, the name being a reference to "Rechenplan" (i.e. computation plan), in Konrad Zuse's terminology designating a single Plankalkül program. ...
(1949–1951) by
Heinz Rutishauser Heinz Rutishauser (30 January 1918 – 10 November 1970) was a Swiss mathematician and a pioneer of modern numerical mathematics and computer science. Life Rutishauser's father died when he was 13 years old and his mother died three years lat ...
. Rutishauser was involved in defining ALGOL 58 and ALGOL 60. The loop body is executed "for" the given values of the loop variable. This is more explicit in
ALGOL ALGOL (; short for "Algorithmic Language") is a family of imperative computer programming languages originally developed in 1958. ALGOL heavily influenced many other languages and was the standard method for algorithm description used by the ...
versions of the for statement where a list of possible values and increments can be specified. In Fortran and
PL/I PL/I (Programming Language One, pronounced and sometimes written PL/1) is a procedural, imperative computer programming language developed and published by IBM. It is designed for scientific, engineering, business and system programming. I ...
, the keyword ''DO'' is used for the same thing and it is called a do-loop; this is different from a do-while loop.


FOR

A for-loop statement is available in most
imperative programming In computer science, imperative programming is a programming paradigm of software that uses statements that change a program's state. In much the same way that the imperative mood in natural languages expresses commands, an imperative program c ...
languages. Even ignoring minor differences in
syntax In linguistics, syntax () is the study of how words and morphemes combine to form larger units such as phrases and sentences. Central concerns of syntax include word order, grammatical relations, hierarchical sentence structure ( constituency) ...
there are many differences in how these statements work and the level of expressiveness they support. Generally, for-loops fall into one of the following categories:


Traditional for-loops

The for-loop of languages like
ALGOL ALGOL (; short for "Algorithmic Language") is a family of imperative computer programming languages originally developed in 1958. ALGOL heavily influenced many other languages and was the standard method for algorithm description used by the ...
, Simula,
BASIC BASIC (Beginners' All-purpose Symbolic Instruction Code) is a family of general-purpose, high-level programming languages designed for ease of use. The original version was created by John G. Kemeny and Thomas E. Kurtz at Dartmouth College ...
, Pascal,
Modula The Modula programming language is a descendant of the Pascal language. It was developed in Switzerland, at ETH Zurich, in the mid-1970s by Niklaus Wirth, the same person who designed Pascal. The main innovation of Modula over Pascal is a modul ...
,
Oberon Oberon () is a king of the fairies in medieval and Renaissance literature. He is best known as a character in William Shakespeare's play ''A Midsummer Night's Dream'', in which he is King of the Fairies and spouse of Titania, Queen of the Fairi ...
,
Ada Ada may refer to: Places Africa * Ada Foah, a town in Ghana * Ada (Ghana parliament constituency) * Ada, Osun, a town in Nigeria Asia * Ada, Urmia, a village in West Azerbaijan Province, Iran * Ada, Karaman, a village in Karaman Province, ...
,
Matlab MATLAB (an abbreviation of "MATrix LABoratory") is a proprietary multi-paradigm programming language and numeric computing environment developed by MathWorks. MATLAB allows matrix manipulations, plotting of functions and data, implementation ...
,
Ocaml OCaml ( , formerly Objective Caml) is a general-purpose programming language, general-purpose, multi-paradigm programming language which extends the Caml dialect of ML (programming language), ML with object-oriented programming, object-oriented ...
, F#, and so on, requires a
control variable A control variable (or scientific constant) in scientific experimentation is an experimental element which is constant (controlled) and unchanged throughout the course of the investigation. Control variables could strongly influence experimenta ...
with start- and end-values, which looks something like this: for i = first to last do statement (* or just *) for i = first..last do statement Depending on the language, an explicit
assignment Assignment, assign or The Assignment may refer to: * Homework * Sex assignment * The process of sending National Basketball Association players to its development league; see Computing * Assignment (computer science), a type of modification to ...
sign may be used in place of the
equal sign The equals sign (British English, Unicode) or equal sign (American English), also known as the equality sign, is the mathematical symbol , which is used to indicate equality in some well-defined sense. In an equation, it is placed between two ...
(and some languages require the word even in the numerical case). An optional step-value (an increment or decrement ≠ 1) may also be included, although the exact syntaxes used for this differs a bit more between the languages. Some languages require a separate declaration of the control variable, some do not. Another form was popularized by the
C programming language ''The C Programming Language'' (sometimes termed ''K&R'', after its authors' initials) is a computer programming book written by Brian Kernighan and Dennis Ritchie, the latter of whom originally designed and implemented the language, as well as ...
. It requires 3 parts: the initialization (
loop variant In computer science, a loop variant is a mathematical function defined on the state space of a computer program whose value is monotonically decreased with respect to a (strict) well-founded relation by the iteration of a while loop under some inva ...
), the condition, and the advancement to the next iteration. All these three parts are optional. This type of "semicolon loops" came from B programming language and it was originally invented by Stephen Johnson. In the initialization part, any variables needed are declared (and usually assigned values). If multiple variables are declared, they should all be of the same type. The condition part checks a certain condition and exits the loop if false, even if the loop is never executed. If the condition is true, then the lines of code inside the loop are executed. The advancement to the next iteration part is performed exactly once every time the loop ends. The loop is then repeated if the condition evaluates to true. Here is an example of the C-style traditional for-loop in
Java Java (; id, Jawa, ; jv, ꦗꦮ; su, ) is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea to the north. With a population of 151.6 million people, Java is the world's List ...
. // Prints the numbers from 0 to 99 (and not 100), each followed by a space. for (int i=0; i<100; i++) System.out.println(); These loops are also sometimes called ''numeric for-loops'' when contrasted with foreach loops (see below).


Iterator-based for-loops

This type of for-loop is a generalisation of the numeric range type of for-loop, as it allows for the enumeration of sets of items other than number sequences. It is usually characterized by the use of an implicit or explicit
iterator In computer programming, an iterator is an object that enables a programmer to traverse a container, particularly lists. Various types of iterators are often provided via a container's interface. Though the interface and semantics of a given iterat ...
, in which the loop variable takes on each of the values in a sequence or other data collection. A representative example in
Python Python may refer to: Snakes * Pythonidae, a family of nonvenomous snakes found in Africa, Asia, and Australia ** ''Python'' (genus), a genus of Pythonidae found in Africa and Asia * Python (mythology), a mythical serpent Computing * Python (pro ...
is: for item in some_iterable_object: do_something() do_something_else() Where is either a data collection that supports implicit iteration (like a list of employee's names), or may in fact be an iterator itself. Some languages have this in addition to another for-loop syntax; notably, PHP has this type of loop under the name , as well as a three-expression for-loop (see below) under the name .


Vectorised for-loops

Some languages offer a for-loop that acts as if processing all iterations in parallel, such as the keyword in FORTRAN 95 which has the interpretation that ''all'' right-hand-side expressions are evaluated before ''any'' assignments are made, as distinct from the explicit iteration form. For example, in the statement in the following pseudocode fragment, when calculating the new value for , except for the first (with ) the reference to will obtain the new value that had been placed there in the previous step. In the version, however, each calculation refers only to the original, unaltered . for i := 2 : N - 1 do A(i) := (i - 1) + A(i) + A(i + 1)/ 3; next i; for all i := 2 : N - 1 do A(i) := (i - 1) + A(i) + A(i + 1)/ 3; The difference may be significant. Some languages (such as FORTRAN 95, PL/I) also offer array assignment statements, that enable many for-loops to be omitted. Thus pseudocode such as would set all elements of array A to zero, no matter its size or dimensionality. The example loop could be rendered as A(2 : N - 1) := (1 : N - 2) + A(2 : N - 1) + A(3 : N)/ 3; But whether that would be rendered in the style of the for-loop or the for all-loop or something else may not be clearly described in the compiler manual.


Compound for-loops

Introduced with
ALGOL 68 ALGOL 68 (short for ''Algorithmic Language 1968'') is an imperative programming language that was conceived as a successor to the ALGOL 60 programming language, designed with the goal of a much wider scope of application and more rigorously d ...
and followed by PL/I, this allows the iteration of a loop to be compounded with a test, as in for i := 1 : N while A(i) > 0 do ''etc.'' That is, a value is assigned to the loop variable ''i'' and only if the ''while expression'' is true will the loop body be executed. If the result were false the for-loop's execution stops short. Granted that the loop variable's value ''is'' defined after the termination of the loop, then the above statement will find the first non-positive element in array ''A'' (and if no such, its value will be ''N + 1''), or, with suitable variations, the first non-blank character in a string, and so on.


Loop counters

In
computer programming Computer programming is the process of performing a particular computation (or more generally, accomplishing a specific computing result), usually by designing and building an executable computer program. Programming involves tasks such as ana ...
, a loop counter is a control variable that controls the iterations of a loop (a computer
programming language A programming language is a system of notation for writing computer programs. Most programming languages are text-based formal languages, but they may also be graphical. They are a kind of computer language. The description of a programming ...
construct). It is so named because most uses of this construct result in the variable taking on a range of integer values in some orderly sequences (example., starting at 0 and end at 10 in increments of 1) Loop counters change with each iteration of a loop, providing a unique value for each individual iteration. The loop counter is used to decide when the loop should terminate and for the program flow to continue to the next instruction after the loop. A common
identifier naming convention In computer programming, a naming convention is a set of rules for choosing the character sequence to be used for identifiers which denote variables, types, functions, and other entities in source code and documentation. Reasons for using a na ...
is for the loop counter to use the variable names i, j, and k (and so on if needed), where i would be the most outer loop, j the next inner loop, etc. The reverse order is also used by some programmers. This style is generally agreed to have originated from the early programming of Fortran, where these variable names beginning with these letters were implicitly declared as having an integer type, and so were obvious choices for loop counters that were only temporarily required. The practice dates back further to
mathematical notation Mathematical notation consists of using symbols for representing operations, unspecified numbers, relations and any other mathematical objects, and assembling them into expressions and formulas. Mathematical notation is widely used in mathem ...
where indices for sums and multiplications are often i, j, etc. A variant convention is the use of reduplicated letters for the index, ii, jj, and kk, as this allows easier searching and search-replacing than using a single letter.


Example

An example of C code involving nested for loops, where the loop counter variables are i and j: for (i = 0; i < 100; i++) For loops in C can also be used to print the reverse of a word. As: for (i = 0; i < 6; i++) for (i = 4; i >= 0; i--) Here, if the input is , the output will be .


Additional semantics and constructs


Use as infinite loops

This C-style for-loop is commonly the source of an
infinite loop In computer programming, an infinite loop (or endless loop) is a sequence of instructions that, as written, will continue endlessly, unless an external intervention occurs ("pull the plug"). It may be intentional. Overview This differs from: * ...
since the fundamental steps of iteration are completely in the control of the programmer. In fact, when infinite loops are intended, this type of for-loop can be used (with empty expressions), such as: for (;;) //loop body This style is used instead of infinite loops to avoid a type conversion warning in some C/C++ compilers. Some programmers prefer the more succinct form over the semantically equivalent but more verbose form.


Early exit and continuation

Some languages may also provide other supporting statements, which when present can alter how the for-loop iteration proceeds. Common among these are the
break Break or Breaks or The Break may refer to: Time off from duties * Recess (break), time in which a group of people is temporarily dismissed from its duties * Break (work), time off during a shift/recess ** Coffee break, a short mid-morning res ...
and continue statements found in C and its derivatives. The break statement causes the inner-most loop to be terminated immediately when executed. The continue statement will move at once to the next iteration without further progress through the loop body for the current iteration. A for statement also terminates when a break, goto, or return statement within the statement body is executed.
ells Ells may refer to: * Ell, a measure of length * Ell (architecture) * Ells (surname), a surname * Ells Field, an airport in Mendocino County, California, United States * Ells River, in Alberta, Canada * Euroleague for Life Sciences See also * E ...
Other languages may have similar statements or otherwise provide means to alter the for-loop progress; for example in FORTRAN 95: DO I = 1, N statements !Executed for all values of "I", up to a disaster if any. IF (no good) CYCLE !Skip this value of "I", continue with the next. statements !Executed only where goodness prevails. IF (disaster) EXIT !Abandon the loop. statements !While good and, no disaster. END DO !Should align with the "DO". Some languages offer further facilities such as naming the various loop statements so that with multiple nested loops there is no doubt as to which loop is involved. Fortran 95, for example: X1:DO I = 1,N statements X2:DO J = 1,M statements IF (trouble) CYCLE X1 statements END DO X2 statements END DO X1 Thus, when "trouble" is detected in the inner loop, the CYCLE X1 (not X2) means that the skip will be to the next iteration for I, ''not'' J. The compiler will also be checking that each END DO has the appropriate label for its position: this is not just a documentation aid. The programmer must still code the problem correctly, but some possible blunders will be blocked.


Loop variable scope and semantics

Different languages specify different rules for what value the loop variable will hold on termination of its loop, and indeed some hold that it "becomes undefined". This permits a
compiler In computing, a compiler is a computer program that translates computer code written in one programming language (the ''source'' language) into another language (the ''target'' language). The name "compiler" is primarily used for programs that ...
to generate code that leaves any value in the loop variable, or perhaps even leaves it unchanged because the loop value was held in a register and never stored to memory. Actual behaviour may even vary according to the compiler's optimization settings, as with the Honywell Fortran66 compiler. In some languages (not C or
C++ C++ (pronounced "C plus plus") is a high-level general-purpose programming language created by Danish computer scientist Bjarne Stroustrup as an extension of the C programming language, or "C with Classes". The language has expanded significan ...
) the loop variable is immutable within the scope of the loop body, with any attempt to modify its value being regarded as a semantic error. Such modifications are sometimes a consequence of a programmer error, which can be very difficult to identify once made. However, only overt changes are likely to be detected by the compiler. Situations where the address of the loop variable is passed as an argument to a
subroutine In computer programming, a function or subroutine is a sequence of program instructions that performs a specific task, packaged as a unit. This unit can then be used in programs wherever that particular task should be performed. Functions may ...
make it very difficult to check, because the routine's behavior is in general unknowable to the compiler. Some examples in the style of Fortran: DO I = 1, N I = 7 !Overt adjustment of the loop variable. Compiler complaint likely. Z = ADJUST(I) !Function "ADJUST" might alter "I", to uncertain effect. normal statements !Memory might fade that "I" is the loop variable. PRINT (A(I), B(I), I = 1, N, 2) !Implicit for-loop to print odd elements of arrays A and B, reusing "I"... PRINT I !What value will be presented? END DO !How many times will the loop be executed? A common approach is to calculate the iteration count at the start of a loop (with careful attention to overflow as in in sixteen-bit integer arithmetic) and with each iteration decrement this count while also adjusting the value of : double counting results. However, adjustments to the value of within the loop will not change the number of iterations executed. Still another possibility is that the code generated may employ an auxiliary variable as the loop variable, possibly held in a machine register, whose value may or may not be copied to on each iteration. Again, modifications of would not affect the control of the loop, but now a disjunction is possible: within the loop, references to the value of might be to the (possibly altered) current value of or to the auxiliary variable (held safe from improper modification) and confusing results are guaranteed. For instance, within the loop a reference to element of an array would likely employ the auxiliary variable (especially if it were held in a machine register), but if is a parameter to some routine (for instance, a ''print''-statement to reveal its value), it would likely be a reference to the proper variable instead. It is best to avoid such possibilities.


Adjustment of bounds

Just as the index variable might be modified within a for-loop, so also may its bounds and direction. But to uncertain effect. A compiler may prevent such attempts, they may have no effect, or they might even work properly - though many would declare that to do so would be wrong. Consider a statement such as for i := first : last : step do A(i) := A(i) / A(last); If the approach to compiling such a loop was to be the evaluation of , and and the calculation of an iteration count via something like once only at the start, then if those items were simple variables and their values were somehow adjusted during the iterations, this would have no effect on the iteration count even if the element selected for division by changed.


List of value ranges

PL/I and Algol 68, allows loops in which the loop variable is iterated over a list of ranges of values instead of a single range. The following PL/I example will execute the loop with six values of i: 1, 7, 12, 13, 14, 15: do i = 1, 7, 12 to 15; /*statements*/ end;


Equivalence with while-loops

A for-loop is generally equivalent to a while-loop: factorial := 1 for counter from 2 to 5 factorial := factorial * counter counter := counter - 1 print counter + "! equals " + factorial is equivalent to: factorial := 1 counter := 1 while counter < 5 counter := counter + 1 factorial := factorial * counter print counter + "! equals " + factorial as demonstrated by the output of the variables.


Timeline of the ''for-loop'' syntax in various programming languages

Given an action that must be repeated, for instance, five times, different languages' for-loops will be written differently. The syntax for a three-expression for-loop is nearly identical in all languages that have it, after accounting for different styles of block termination and so on.


1957: FORTRAN

Fortran's equivalent of the loop is the loop, using the keyword do instead of for, The syntax of Fortran's loop is: DO label counter = first, last, step statements label statement The following two examples behave equivalently to the three argument for-loop in other languages, initializing the counter variable to 1, incrementing by 1 each iteration of the loop and stopping at five (inclusive). DO 9, COUNTER = 1, 5, 1 WRITE (6,8) COUNTER 8 FORMAT( I2 ) 9 CONTINUE In Fortran 77 (or later), this may also be written as: do counter = 1, 5 write(*, '(i2)') counter end do The step part may be omitted if the step is one. Example: * DO loop example. PROGRAM MAIN SUM SQ = 0 DO 199 I = 1, 9999999 IF (SUM SQ.GT.1000) GO TO 200 199 SUM SQ = SUM SQ + I**2 200 PRINT 206, SUMSQ 206 FORMAT( I2 ) END Spaces are irrelevant in fixed-form Fortran statements, thus is the same as . In the modern free-form Fortran style, blanks are significant. In Fortran 90, the may be avoided by using an statement. * DO loop example. program main implicit none integer :: sumsq integer :: i sumsq = 0 do i = 1, 9999999 if (sumsq > 1000.0) exit sumsq = sumsq + i**2 end do print *, sumsq end program


1958: ALGOL

ALGOL 58 introduced the statement, using the form as Superplan: FOR ''Identifier'' = ''Base'' (''Difference'') ''Limit'' For example to print 0 to 10 incremented by 1:
FOR x = 0 (1) 10 BEGIN
PRINT (FL) = x END


1960: COBOL

COBOL was formalized in late 1959 and has had many elaborations. It uses the PERFORM verb which has many options. Originally all loops had to be out-of-line with the iterated code occupying a separate paragraph. Ignoring the need for declaring and initialising variables, the COBOL equivalent of a ''for''-loop would be. PERFORM SQ-ROUTINE VARYING I FROM 1 BY 1 UNTIL I > 1000 SQ-ROUTINE ADD I**2 TO SUM-SQ. In the 1980s the addition of in-line loops and "structured" statements such as END-PERFORM resulted in a ''for''-loop with a more familiar structure. PERFORM VARYING I FROM 1 BY 1 UNTIL I > 1000 ADD I**2 TO SUM-SQ. END-PERFORM If the PERFORM verb has the optional clause TEST AFTER, the resulting loop is slightly different: the loop body is executed at least once, before any test.


1964: BASIC

Loops in BASIC are sometimes called for-next loops. 10 REM THIS FOR LOOP PRINTS ODD NUMBERS FROM 1 TO 15 20 FOR I = 1 TO 15 STEP 2 30 PRINT I 40 NEXT I Notice that the end-loop marker specifies the name of the index variable, which must correspond to the name of the index variable in the start of the for-loop. Some languages (PL/I, FORTRAN 95 and later) allow a statement label on the start of a for-loop that can be matched by the compiler against the same text on the corresponding end-loop statement. Fortran also allows the and statements to name this text; in a nest of loops this makes clear which loop is intended. However, in these languages the labels must be unique, so successive loops involving the same index variable cannot use the same text nor can a label be the same as the name of a variable, such as the index variable for the loop.


1964: PL/I

do counter = 1 to 5 by 1; /* "by 1" is the default if not specified */ /*statements*/; end; The statement may be used to exit the loop. Loops can be labeled, and ''leave'' may leave a specific labeled loop in a group of nested loops. Some PL/I dialects include the statement to terminate the current loop iteration and begin the next.


1968: Algol 68

ALGOL 68 has what was considered ''the'' universal loop, the full syntax is:
FOR i FROM 1 BY 2 TO 3 WHILE i≠4 DO ~ OD
Further, the single iteration range could be replaced by a list of such ranges. There are several unusual aspects of the construct * only the portion was compulsory, in which case the loop will iterate indefinitely. * thus the clause , will iterate exactly 100 times. * the ''syntactic element'' allowed a programmer to break from a loop early, as in:
INT sum sq := 0;
FOR i
 WHILE
  print(("So far:", i, new line)); # Interposed for tracing purposes. #
  sum sq ≠ 70↑2                    # This is the test for the WHILE   #
DO
  sum sq +:= i↑2
OD
Subsequent ''extensions'' to the standard Algol68 allowed the syntactic element to be replaced with and to achieve a small optimization. The same compilers also incorporated: ;: for late loop termination. ;: for working on arrays in
parallel Parallel is a geometric term of location which may refer to: Computing * Parallel algorithm * Parallel computing * Parallel metaheuristic * Parallel (software), a UNIX utility for running programs in parallel * Parallel Sysplex, a cluster of ...
.


1970: Pascal

for Counter := 1 to 5 do (*statement*); Decrementing (counting backwards) is using keyword instead of , as in: for Counter := 5 downto 1 do (*statement*); The numeric-range for-loop varies somewhat more.


1972: C/C++

for (initialization; condition; increment/decrement) statement The is often a block statement; an example of this would be: //Using for-loops to add numbers 1 - 5 int sum = 0; for (int i = 0; i < 5; ++i) The ISO/IEC 9899:1999 publication (commonly known as
C99 C99 (previously known as C9X) is an informal name for ISO/IEC 9899:1999, a past version of the C programming language standard. It extends the previous version ( C90) with new features for the language and the standard library, and helps impl ...
) also allows initial declarations in loops. All the three sections in the for loop are optional, with an empty condition equivalent to true.


1972: Smalltalk

1 to: 5 do: "statements" /syntaxhighlight> Contrary to other languages, in
Smalltalk Smalltalk is an object-oriented, dynamically typed reflective programming language. It was designed and created in part for educational use, specifically for constructionist learning, at the Learning Research Group (LRG) of Xerox PARC by Alan Ka ...
a for-loop is not a
language construct In computer programming, a language construct is a syntactically allowable part of a program that may be formed from one or more lexical tokens in accordance with the rules of the programming language. The term "language construct" is often used ...
but defined in the class Number as a method with two parameters, the end value and a closure, using self as start value.


1980: Ada

for Counter in 1 .. 5 loop -- statements end loop; The ''exit'' statement may be used to exit the loop. Loops can be labeled, and ''exit'' may leave a specifically labeled loop in a group of nested loops: Counting: for Counter in 1 .. 5 loop Triangle: for Secondary_Index in 2 .. Counter loop -- statements exit Counting; -- statements end loop Triangle; end loop Counting;


1980: Maple

Maple has two forms of for-loop, one for iterating of a range of values, and the other for iterating over the contents of a container. The value range form is as follows: for ''i'' from ''f'' by ''b'' to ''t'' while ''w'' do ''# loop body'' od; All parts except do and od are optional. The for ''i'' part, if present, must come first. The remaining parts (from ''f'', by ''b'', to ''t'', while ''w'') can appear in any order. Iterating over a container is done using this form of loop: for ''e'' in ''c'' while ''w'' do ''# loop body'' od; The in ''c'' clause specifies the container, which may be a list, set, sum, product, unevaluated function, array, or an object implementing an iterator. A for-loop may be terminated by od, end, or end do.


1982: Maxima CAS

In
Maxima CAS Maxima () is a computer algebra system (CAS) based on a 1982 version of Macsyma. It is written in Common Lisp and runs on all POSIX platforms such as macOS, Unix, BSD, and Linux, as well as under Microsoft Windows and Android. It is free softwa ...
one can use also non integer values : for x:0.5 step 0.1 thru 0.9 do /* "Do something with x" */


1982: PostScript

The for-loop, written as initialises an internal variable, executes the body as long as the internal variable is not more than limit (or not less, if increment is negative) and, at the end of each iteration, increments the internal variable. Before each iteration, the value of the internal variable is pushed onto the stack. 1 1 6 for There is also a simple repeat-loop. The repeat-loop, written as , repeats the body exactly X times. 5 repeat


1983: Ada 83 and above

procedure Main is Sum_Sq : Integer := 0; begin for I in 1 .. 9999999 loop if Sum_Sq <= 1000 then Sum_Sq := Sum_Sq + I**2 end if; end loop; end;


1984: MATLAB

for n = 1:5 -- statements end After the loop, would be 5 in this example. As is used for the
Imaginary unit The imaginary unit or unit imaginary number () is a solution to the quadratic equation x^2+1=0. Although there is no real number with this property, can be used to extend the real numbers to what are called complex numbers, using addition an ...
, its use as a loop variable is discouraged.


1987: Perl

for ($counter = 1; $counter <= 5; $counter++) for (my $counter = 1; $counter <= 5; $counter++) for (1..5) statement for 1..5; # almost same (only 1 statement) with natural language order for my $counter (1..5) (Note that "
there's more than one way to do it There's more than one way to do it (TMTOWTDI or TIMTOWTDI, pronounced ''Tim Toady'') is a Perl programming motto. The language was designed with this idea in mind, in that it “doesn't try to tell the programmer how to program.” As proponents of ...
" is a Perl programming motto.)


1988: Mathematica

The construct corresponding to most other languages' for-loop is called Do in Mathematica Do [x_.html" ;"title=".html" ;"title="[x">[x ">.html" ;"title="[x">[x Mathematica also has a For construct that mimics the for-loop of C-like languages For[x= 0 , x <= 1, x += 0.1, f[x] ]


1989: Bash

# first form for i in 1 2 3 4 5 do # must have at least one command in loop echo $i # just print value of i done # second form for (( i = 1; i <= 5; i++ )) do # must have at least one command in loop echo $i # just print value of i done Note that an empty loop (i.e., one with no commands between and ) is a syntax error. If the above loops contained only comments, execution would result in the message "syntax error near unexpected token 'done'".


1990: Haskell

The built-in imperative ''forM_'' maps a monadic expression into a list, as forM_ ..5$ \indx -> do statements or get each iteration result as a list in statements_result_list <- forM ..5$ \indx -> do statements But, if you want to save the space of the ..5list, a more authentic monadic ''forLoop_'' construction can be defined as import Control.Monad as M forLoopM_ :: Monad m => a -> (a -> Bool) -> (a -> a) -> (a -> m ()) -> m () forLoopM_ indx prop incr f = do f indx M.when (prop next) $ forLoopM_ next prop incr f where next = incr indx and used as: forLoopM_ (0::Int) (< len) (+1) $ \indx -> do -- whatever with the index


1991: Oberon-2, Oberon-07, or Component Pascal

FOR Counter := 1 TO 5 DO (* statement sequence *) END Note that in the original Oberon language the for-loop was omitted in favor of the more general Oberon loop construct. The for-loop was reintroduced in Oberon-2.


1991: Python

Python does not contain the classical for loop, rather a foreach loop is used to iterate over the output of the built-in range() function which returns an iterable sequence of integers. for i in range(1, 6): # gives i values from 1 to 5 inclusive (but not 6) # statements print(i) # if we want 6 we must do the following for i in range(1, 6 + 1): # gives i values from 1 to 6 # statements print(i) Using range(6) would run the loop from 0 to 5.


1993: AppleScript

repeat with i from 1 to 5 -- statements log i end repeat You can also iterate through a list of items, similar to what you can do with arrays in other languages: set x to repeat with i in x log i end repeat You may also use to exit a loop at any time. Unlike other languages, AppleScript does not currently have any command to continue to the next iteration of a loop.


1993: Crystal

for i = start, stop, interval do -- statements end So, this code for i = 1, 5, 2 do print(i) end will print: 1 3 5 For-loops can also loop through a table using ipairs() to iterate numerically through arrays and pairs() to iterate randomly through dictionaries. Generic for-loop making use of closures: for name, phone, address in contacts() do -- contacts() must be an iterator function end


1995:

CFML ColdFusion Markup Language, more commonly known as CFML, is a scripting language for web development that runs on the JVM, the .NET framework, and Google App Engine. Multiple commercial and open source implementations of CFML engines are availab ...


Script syntax

Simple index loop: for (i = 1; i <= 5; i++) Using an array: for (i in ,2,3,4,5 Using a list of string values: loop index="i" list="1;2,3;4,5" delimiters=",;" The above example is only available in the dialect of CFML used by
Lucee Lucee is an open source implementation of a lightweight dynamically-typed scripting language for the Java virtual machine (JVM). The language is used for rapid development of web applications that compile directly to Java bytecode, and is comp ...
and
Railo Railo Server, commonly referred to as Railo ( ), is open source software which implements the general-purpose CFML server-side scripting language, often used to create dynamic websites, web applications and intranet systems. CFML is a dynami ...
.


Tag syntax

Simple index loop: Using an array: ,2,3,4,5"> Using a "list" of string values:


1995: Java

for (int i = 0; i < 5; i++) For the extended for-loop, see .


1995: JavaScript

JavaScript supports C-style "three-expression" loops. The and statements are supported inside loops. for (var i = 0; i < 5; i++) Alternatively, it is possible to iterate over all keys of an array. for (var key in array)


1995: PHP

This prints out a triangle of * for ($i = 0; $i <= 5; $i++)


1995: Ruby

for counter in 1..5 # statements end 5.times do , counter, # counter iterates from 0 to 4 # statements end 1.upto(5) do , counter, # statements end
Ruby A ruby is a pinkish red to blood-red colored gemstone, a variety of the mineral corundum ( aluminium oxide). Ruby is one of the most popular traditional jewelry gems and is very durable. Other varieties of gem-quality corundum are called sa ...
has several possible syntaxes, including the above samples.


1996: OCaml

See expression syntax. (* for_statement := "for" ident '=' expr ( "to" ∣ "downto" ) expr "do" expr "done" *) for i = 1 to 5 do (* statements *) done ;; for j = 5 downto 0 do (* statements *) done ;;


1998: ActionScript 3

for (var counter:uint = 1; counter <= 5; counter++)


2008: Small Basic

For i = 1 To 10 ' Statements EndFor


2008: Nim

Nim has a foreach-type loop and various operations for creating iterators.https://nim-lang.org/docs/system.html#...i%2CT%2CT ".. iterator" for i in 5 .. 10: # statements


2009: Go

for i := 0; i <= 10; i++


2010: Rust

for i in 0..10


2012: Julia

for j = 1:10 # statements end


See also

*
Do while loop In most computer programming languages a do while loop is a control flow statement that executes a block of code and then either repeats the block or exits the loop depending on a given boolean condition. The ''do while'' construct consists o ...
*
Foreach In computer programming, foreach loop (or for each loop) is a control flow statement for traversing items in a collection. is usually used in place of a standard loop statement. Unlike other loop constructs, however, loops usually maintai ...
*
While loop In most computer programming languages, a while loop is a control flow statement that allows code to be executed repeatedly based on a given Boolean condition. The ''while'' loop can be thought of as a repeating if statement. Overview The ' ...


References

{{Reflist Articles with example Ada code Articles with example ALGOL 68 code Articles with example C code Articles with example Fortran code Articles with example Perl code Iteration in programming Articles with example Python (programming language) code