U nauci o kompjuterima for-petlja (ili jednostavnije for petlja) je kontrolna izjava u programskim jezicima za navođenje iteracije (ponavljanja) , koja omogućava kodu da se izvršava u više navrata. Sintaksa for petlje je napravljena u stilu programskog jezika u kojem se koristi ili je pozajmljena iz starijih programskih jezika, pa tako programski jezici koji su potomci ili izdanci istog jezika će često koristiti istu reč da označe iterator, npr., potomci ALGOL-a koriste „for“, dok potomci Fortran-a koriste „do“. Postoje i druge mogućnosti, na primer COBOL koristi „PERFORM“.

dijagram protoka for petlje

Za razliku od drugih petlji, kao što je while petlja, for petlje često odlikuju izraženiji brojači ili izraženije promenljive. Ovo omogućava telu for petlje (kod koji se u više navrata izvršava) da zna redosled svakog ponavljanja. For petlje se uglavnom koriste kada se broj ponavljanja zna pre nego što se petlja napiše. Kada se while petlja može napisati kao For petlja i kada se zna broj ponavljanja, bolje je koristiti For petlju jer je kraća.

Ime For petlje potiče od engleske reči for, koja se koristi kao ključna reč u najvećem broju programskih da bi se uvela for petlja. Ovaj izraz se koristio još u ALGOL-u 58, a postao je popularan kasnije u ALGOL-u 60; on je direktan prevod nemačke reči für, korišćene u Superplan-u (1949-1951) Hajnca Rutishausera, koji je takođe bio uključen u programiranju ALGOL-a 58 i ALGOL-a 60. Telo petlje izvršava „for“ za vrednosti promenljivih iz petlje, i ovo je mnogo izraženije u ALGOL izjavama, u kojima se liste potencijalnih vrednosti i/ili koraka mogu odrediti.

U FORTRAN i PL/I, se koristi ključna reč DO, a petlja se zove do petlja, i pošto je skoro identična for petlji opisanoj ovde, nećemo je koristiti kako je ne bi mešali sa do while petljom.

Vrste for petlji

uredi

Izjave For petlji su dostupne u većini imperativnih programskih jezika. Čak i ignorišući manje razlike u sintaksama postoji mnogo razlika u tome kako ove izjave rade i kakav nivo izražajnosti podržavaju. Generalno for petlje se mogu podeliti na:

Tradicionalne for petlje

uredi

Tradicionalne for petlje u C / C++ sastoje se iz 3 dela: uvođenje, uslov i naknadna misao i sva 3 dela su opciona.[1][2]

for (УВОЂЕЊЕ; УСЛОВ; НАКНАДНА МИСАО) 
{
    // Код тела фор петље иде овде
}

U uvođenju se navode (verovatno i dodeljuju) sve potrebne promenljive. Tip promenljivih bi trebalo da bude isti ako koristite više promenljivih u delu uvođenja. Uslov proverava uslov, i prekida petlju ako uslov daje logički odgovor netačno. Naknadna misao se izvršava samo jednom svaki put kada se petlja završava i ponavlja.

Evo primera tradicionalne for petlje u Javi.

for (int i = 0; i < 100; i++) // Штампа бројеве од 0 до 99 (не и 100), сваки одвојен размаком.
{
    System.out.print(i);
    System.out.print(' ');
}
System.out.println();

For petlje zasnovane na ponavljanju

uredi

Ovaj tip for petlje je kopija for petlje zasnovane na numeričkim opsezima; jer omogućava brojanje skupova stavki koji ne moraju biti nizovi brojeva. Obično se odlikuje upotrebom implicitnog ili eksplicitnog iteratora, u kojoj promenljiva petlje preuzima vrednost iz sekvenci ili iz druge moguće kolekcije. Reprezentativan primer u Pajtonu je:

for stavka in objekat:
    uradi nešto
    uradi nešto drugo

Gde je објекат ili kolekcija koja podržava implicitno ponavljanje (kao lista imena zaposlenih) ili je to možda sam iterator. Neki jezici imaju ovo kao dodatak drugim sintaksama for petlje; posebno PHP ima ovaj tip petlje pod imenom for each, kao i troizraznu for petlju (videti dole) pod imenom for.

Vektorizovane for petlje

uredi

Neki jezici nude for petlje koje obavljaju if proces na svim ponavljanjima paralelno, za razliku od eksplicitne forme ponavljanja. Na primer to radi ključna reč for all u FORTRAN 95, koji ima tumačenje da su svi izrazi sa desne strane vrednovani pre nego što su zadaci napravljeni. U for izjavama u sledećim delovima pseudokoda, gde računajući novu vrednost za A(i), osim za prvu (za i = 2), pozivanje na A(i - 1) će dobiti novu vrednost koja će biti postavljena na isto mesto kao u prethodnom koraku. U for all verziji, svaki račun odnosi se samo na originalan, neizmenjeni A.

for     i := 2 : N - 1 do A(i) := [A(i - 1) + A(i) + A(i + 1)] / 3; next i;
for all i := 2 : N - 1 do A(i) := [A(i - 1) + A(i) + A(i + 1)] / 3;

Razlika može biti značajna.

Neki jezici (kao FORTRAN 95, PL/I) takođe nude niz izjava za dodeljivanje, koje omogućuju da mnoge for petlje budu izostavljene. Tako će pseudokod A := 0; postaviti sve elemente niza A na nulu, bez obzira na njenu veličinu ili dimenziju. Na primer takva petlja može biti:

 A(2 : N - 1) := [A(1 : N - 2) + A(2 : N - 1) + A(3 : N)] / 3;

Da li je izražena u stilu for petlje, for all petlje ili neke druge možda neće biti tačno opisano u uputstvu.

Spojene for petlje

uredi

Uvedene u ALGOL 68 i ispraćene sa PL/I, omogućavaju da ponavljanje petlje bude spojeno sa ispitivanjem, kao u

for i := 1 : N while A(i) > 0 uradi itd.

To jest, vrednost je dodeljena promenljivoj i i samo ako je izraz tačan telo petlje će se izvršiti. Ako je vrednost netačna izračunavanje se završava. Pod pretpostavkom da je vrednost promenljive definisana nakon završetka petlje, gornja naredba će pronaći prvi ne pozitivan element niza A (ako takav ne postoji, negova vrednost će biti N+1) ili, sa odgovarajućim varijantama, prvi ne prazan karakter u niskoj, itd.

Dodatne semantike i konstrukcije

uredi

Korišćenje beskonačne petlje

uredi

Ovaj S-stil for petlji je još od osnovnih koraka ponavljanja je potpuno u kontroli programera. U stvari, kada su beskonačne petlje namerno stvorene, ova vrsta for petlji se može koristiti (sa praznim izrazima) kao:

for (;;)
   //тело петље

Ovaj stil se koristi umesto beskonačne while (1) petlje da bi se izbeglo upozorenje u nekim S/S++ kompajlerima.[3] Neki programeri vole više jezgrovitu for (;;) formu nego semantički ekvivalentnu ali opširniju while (tačno) formu.

Rani izlaz i nastavak

uredi

Neki jezici takođe mogu da pruže i druge prateće izjave, koje kada su prisutne mogu da menjaju ponavljanje for petlje. Zajedničke među njima su break i continue izjave koje se nalaze u C programskom jeziku i njegovim izdancima. Izjava break prekida petlju odmah nakon zadatog uslova. Izjava continue će odmah krenuti na sledeću iteraciju bez daljeg napretka kroz telo petlje za tekuću iteraciju. Ostali jezici mogu imati slične izjave ili da na drugi način obezbede sredstva za menjanje for petlje ; na primer u FORTRAN-u 95:

DO I = 1, N
  изјаве                   !Извршава све вредности за "I", све до катастрофе ако постоји.
  IF (није добро) CYCLE    !Прескаче ову вредност за "I", наставља са следећом.
  изјаве                   !Извршава само где је добро.
  IF (катастрофа) EXIT     !Напушта петљу.
  изјаве                   !Све док је добро, док није катастрофа.

END DO !Треба да се усклади са "DO".

Obim promenljive u petlji i semantika

uredi

Različiti jezici navode različita pravila za ono što će vrednost promenljive u petlji imati nakon završetka petlje. Ovo dozvoljava prevodiocu da generiše kod koji ne ostavlja nikakvu vrednost promenljivoj iz petlje, ili možda čak i ostavlja, ali je to nepromenjena vrednost petlje i nikada se ne čuva u memoriji. Stvarno ponašanje može čak da varira u skladu sa postavkama optimizacije kompajlera, kao sa Honywell Fortran66 kompajlerom.

U nekim jezicima (ali ne u S i C++) petlja promenljive je nepromenljiva u okviru tela petlje, svaki pokušaj da se promeni njena vrednost smatra se semantičkom greškom. Takve modifikacije su ponekad posledica greške programera, što može biti veoma teško identifikovati. Međutim sama greška će verovatno biti otkrivena od strane ljudi koji proveravaju kod. Situacije u kojima adrese promenljivih u petlji prolaze kao argumenti potprograma su veoma teško proverljive, jer ponašanje rutine je u celini nepoznato u kompajleru. Neki primeri u Fortranovom stilu:

DO I = 1, N
  I = 7                           !Очито подешавање променљиве из петље. Вероватно приговор.
  Z = ADJUST(I)                   !Функција "ADJUST" ће изменити "I", у неизвесно.
  нормалне изјаве                 !Меморија ће избрисати да је "I" променљива из петље.
  PRINT (A(I), B(I), I = 1, N, 2) !Користи петљу да одштампа непарне елементе низа А и В, поново користећи "I"…
  PRINT I                         !Која вредност ће бити одштампана?
END DO !Колико пута ће петља бити рачуната?

Zajednički pristup je da izračuna tačku ponavljanja na početku petlje (sa posebnim osvrtom na izlivanje kao u for i := 0 : 65535 do ... ; u šesnaestobitnom intidžeru aritmetike) i sa svakim novim izdanjem smanji ovo, računajući while takođe dodavanjem vrednosti I: duplo brojanje rezultata. Takođe prilagođavanje vrednosti I: duplo brojati rezultate. Međutim, prilagođavanja vrednosti I u okviru petlje neće promeniti broj ponavljanja izvršenja.

Još jedna mogućnost je da je kod generisan i može se koristiti pomoćnu promenljive kao promenljiva petlje, verovatno sačuvanom u registru, čija vrednost može ili ne može biti kopirana u I na svakom ponavljanju. Opet, modifikacije I neće uticati na kontrolu petlje, ali sada je na raskrsnici moguće: u okviru petlje, reference vrednosti I mogu biti (eventualno izmenjene) sadašnje vrednosti I ili pomoćne promenljive I pa su zbunjujući rezultati zagarantovani. Na primer, u okviru petlje referencu na element I niza verovatno će zaposliti pomoćnu promenljive (pogotovo ako je održana u registru), ali ako je parametar na neku rutinu (na primer, štampanje izjava otkriva svoju vrednost), verovatno bi pozivalo na odgovarajuće promenljive I. Najbolje je da se izbegnu takve mogućnosti.

Prilagođavanje granica

uredi

Baš kao što indeks promenljive može biti modifikovan u okviru for petlji, tako se mogu menjati i granice i pravci. Ali sa neizvesnim efektima. Prevodilac može sprečiti takve pokušaje, jer oni možda nemaju nikakav efekat, ili čak možda nakon toga neće raditi ispravno, mada bi mnogi rekli da je pogrešno to uraditi. Razmotrite izjavu kao for i := first : last : step do

  A(i) := A(i) / A(last);

Ako pristup sastavljanju takve petlje treba da bude procena prvog, poslednjeg člana, broja koraka i obračun ponavljanja sa nečim kao (poslednji-prvi)/korak samo na početku, i onda ako te stavke budu jednostavne promenljive i njihove vrednosti su nekako uvećane tokom ponavljanja, to neće imati nikakvog efekta na iteraciju count iako je element izabran za podelu sa A (poslednji) promenjen.

Lista vrednosti opsega

uredi

PL/I i ALGOL 68 omogućava petljama u kojima se nalazi promenljiva da se ponavljaju izvan opsega vrednosti umesto u jednom opsegu. Sledi PL/I primer koji izračunava petlju sa 6 vrednosti za i:1,7,12,13,14,15:

do i = 1, 7, 12 to 15;
  /*изјаве*/
end;

Ekvivalentnost sa while petljom

uredi

For petlja se može konvertovati u ekvivalentnu while petlju dopisivanjem brojača promenljive direktno. Sledeći pseudokod pokazuje ovu tehniku:

faktorijel = 1
 for broj from 1 to 5
     faktorijel = faktorijel * broj

Lako se prevodi u while petlju:

faktorijel = 1
 broj = 1
 while broj <= 5
    faktorijel = faktorijel * broj
    broj = broj + 1

Ovaj prevod je malo komplikovan za jezike koji dozvoljavaju skakanje do novog ponavljanja u petlji (kao continue izjava u S-u). Ove izjave će obično implicitno povećavati broj petlje, ali ne i ekvivalent while petlje (jer u ovom drugom slučaju broj nije sastavni deo konstrukcije petlje). Bilo koji prevod će morati da stavi sve izjave unutar bloka koji eksplicitno povećava broj pre pokretanja izjave.

Hronologija sintakse for petlje u raznim programskim jezicima

uredi

Na osnovu akcije koja mora biti ponovljena, na primer, pet puta, različiti jezici će for petlju napisati drugačije. Sintaksa za tri izraza for petlje je skoro identična u svim jezicima koji ga imaju, nakon različitih stilova bloka-kraj petlje i tako dalje.

1957: FORTRAN

uredi

Dok koristite ključnu reč do umesto for, ovaj tip FORTRAN-ove do petlje se ponaša slično kao troargumentna for petlja u ostalim jezicima. Ovaj primer se ponaša isto kao ostali, inicijalizujući broj promenljive na 1, uvećavajući je za 1 u svakoj iteraciji petlje i stopirati kada dostigne vrednost 5.

do broj = 1, 5, 1
  write(*, '(i2)') broj
end do

U FORTRAN-u for petlja je ekvivalentna sa DO petljom. Sintaksa Fortran-ove DO petlje je:

         DO ознака број=почетак, крај, корак
         изјаве
  ознака изјава

Gde se deo koraka može izostaviti ukoliko je korak jedan. Primer: (prostori su irelevantni u Fortran izjavama, tako SUM SQ je isto kao SUMSQ)

! Пример DO петље
       PROGRAM MAIN
         SUM SQ = 0
         DO 101 I = 1, 9999999
           IF (SUM SQ.GT.1000) GO TO 109
           SUM SQ = SUM SQ + I**2
101 CONTINUE
109 CONTINUE
       END

1958: Algol

uredi

Algol je prvi put formalizovan u izveštaju Algol58.

1960: COBOL

uredi

COBOL je formalizovan krajem 1959 god. I imao je mnogo elaboracija. Koristi PERFORM reč koja ima mnogo opcija, uz kasnije dodavanje „sastavnih“ izjava kao što su END-PERFORM. Ignorisanjem potrebe za deklarisanjem i inicijalizacijom promenljive, ekvivalentno sa for petljom će biti:

      PERFORM VARYING I FROM 1 BY 1 UNTIL I > 1000
             ADD I**2 TO SUM-SQ.
      END-PERFORM

Ako reč PERFORM ima opcioni dodatak TEST AFTER, dobijena petlja je nešto drugačija: telo petlje izvršava se najmanje jednom, pre bilo kakvog testa.

1964: BASIC

uredi

Petlje u BASIC ponekad se nazivaju for next petlje.

For I = 1 to 5;
 Print I;
Next I

Obratite pažnju da marker kraja petlje navodi ime indeksa promenljive, koja mora da odgovara imenu indeksa promenljive na početku for petlje. Neki jezici (PL/I, FORTRAN 95 i kasnije) omogućavaju oznaku izjave na početku for petlje tako da može biti uhvaćena od strane kompajlera u odnosu na isti tekst na odgovarajućoj izjavi end. Fortran takođe omogućava EXIT i CYCLE izjave da bi označili ime ovog teksta; u gnezdu petlje ovo čisti petlju koja je namenjena. Međutim, na ovim jezicima etikete moraju da budu jedinstvene, tako uzastopne petlje koje uključuju isti indeks promenljive ne mogu da koriste isti tekst, niti može etiketa biti ista kao ime promenljive, kao što je indeks promenljive u for petlji.

1964: PL/I

uredi
do broj = 1 to 5 by 1; /* "by 1" је подразумевано ако ништа није наведено */
  /*изјаве*/;
  end;

Izjava LEAVE može da se koristi za izlazak iz petlje. Petlja može biti označena, i leave će možda ostaviti posebnu petlju u grupi gnezda petlji. Neki PL/I dijalekti uključuju izjavu ITERATE da prekine trenutnu iteraciju petlje i da počne sledeća.

1968: Algol 68

uredi

Algol68 ima ono što je smatrano univerzalnom petljom, puna sintaksa je:

FOR i FROM 1 BY 2 TO 3 WHILE i≠4 DO ~ OD

Dalje, jedan opseg ponavljanja može biti zamenjen listom takvih opsega. Postoji nekoliko neobičnih aspekata konstrukcije.

  • samo "do ~ od" deo je obavezan, u ovom slučaju petlja će se ponavljati unedogled.
  • tako će se deo "to 100 do ~ od" ponoviti tačno 100 puta.
  • element "while" će dozvoliti programeru da prekine for petlju ranije, kao u:
INT sum sq := 0;
FOR i
 WHILE
  print(("Do sada:", i, new line)); # Уведено за сврху праћења. #
  sum sq ≠ 70↑2                    # Ово је тест за WHILE   #
DO
  sum sq +:= i↑2
OD

1970:Pascal

uredi
for Broj := 1 to 5 do
  (*изјава*);

Opadanje (računajući unazad) koristi „downto“ ključnu reč umesto „to“, kao u:

for Broj := 5 downto 1 do
  (*изјава*);

Numerički opseg for petlje varira nešto više.

1972: C/C++

uredi
for (иницијализација; услов; увећање/смањење)
    изјава

Izjava je obično blok izjava; primer ovoga je:

//Коришћење for петљи за додавање бројева 1 - 5
int sum = 0;
for (int i = 1; i < 6; ++i) {
    sum += i;
}

1972: Smalltalk

uredi
1 to: 5 do: [ :broj | "изјаве" ]

Za razliku od drugih jezika, u Smalltalk-u for petlja nije jezička konstrukcija, ali je definisana u klasi Broj kao metod sa dva parametra, na kraju vrednosti i zatvaranja, koristeći sebe kao početnu vrednost.

1980: Ada

uredi
for Broj in 1 .. 5 loop
   -- изјаве
end loop;

Izjava exit može da se koristi za izlazak iz petlje. Petlje mogu biti označene, a izlaz može ostaviti posebno označenu petlju u grupu ugnežđenih petlji:

Racun:
    for Broj in 1 .. 5 loop
   Trougao:
       for Secondary_Index in 2 .. Broj loop
          -- изјаве
          exit Račun;
          -- изјаве
       end loop Trougao;
    end loop Račun;

1980: Maple

uredi

Maple ima dva oblika for petlji, jedan za ponavljanje opsega vrednosti, a drugi za ponavljanja sadržaja kontejnera. Vrednost opsega je sledeći:

for i from f by b to t while w do
    # тело петље
od;

Svi delovi osim do i od su opcioni. "For i" deo, ako je prisutan, mora biti prvi. Preostali deo ("from f", "by b", "to t", "while w") može da se pojavi u bilo kom redosledu.

Iterativno preko posude vrši se koristeći ovaj oblik petlje:

for e in c while w do
    # тело петље
od;

"In c" deo precizira kontejner, koji može biti lista, skup, zbir, proizvod, funkcija, niz, ili objekat sprovođenje iterator.

For petlja može se raskinuti sa od, end, ili end do.

1982: Maxima CAS

uredi

U Maxima CAS-u mogu se koristiti i ne celobrojne vrednosti:

for x:0.5 step 0.1 thru 0.9 do
    /* "Ради нешто са x" */

1982: PostScript

uredi

For petlja, napisana kao [почетна] [прираст] [лимит] {...}for započinje sa unutrašnjom promenljivom, i izvršava telo dok unutrašnja promenljiva nije viša od limita (ili ne manja, ako je negativan priraštaj ) i, na kraju svake iteracije, povećava unutrašnju promenljivu. Pre svakog ponavljanja, vrednost unutrašnje promenljive je prebačena u stek.[4]

1 1 6 {ИЗЈАВЕ} for

Tu je takođe i prosta repeat petlja. Repeat petlja, napisana sa H { ... } repeat ponavlja telo tačno H puta.[5]

5 { ИЗЈАВЕ } repeat

1983: Ada 83 i iznad

uredi
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

uredi
for i = 1:5 
     -- изјаве
end

1987: Perl

uredi
for ($broj = 1; $broj <= 5; $broj++) { # садашње или претходно дефинисане променљиве
  # изјаве;
}
for (my $broj = 1; $broj <= 5; $broj++) { # променљиве из петље
  # изјаве;
}
for (1..5) { # променљиве имплицитно назване $_; 1..5 стварају листе од 5 елемената
  # изјаве;
}
изјава for 1..5; # готово иста (само 1 изјава) са природним низом
for my $broj (1..5) { # променљиве из петље
  # изјаве;
}

1988: Mathematica

uredi

Konstrukcija for petlje koja odgovara većini drugih jezika u Mathematica se naziva Do.

Do[f[x], {x, 0, 1, 0.1}]

Mathematica takođe ima For konstrukciju koji imitira for petlju S jezika.

For[x= 0 , x <= 1, x += 0.1,
    f[x]
]

1989: Bash

uredi
# прва форма
for i in 1 2 3 4 5
do
    # мора имати најмање једну команду у петљи
    echo $i  # само штампа вредност i
done
# друга форма
for (( i = 1; i <= 5; i++ ))
do
    # мора имати најмање једну команду у петљи
    echo $i  # само штампа вредност i
done

Imajte na umu da se prazna petlja (tj jedna bez komandi između do i done)tretira kao sintaksna greška. Ako iznad petlje sadrži samo komentare, izvršenje će rezultirati porukom "синтаксна грешка код неочекиваног знака 'Done'".

1990: Haskell

uredi

Ugrađeni imperativ forM_ mapira izraz u listu, kao

forM_ [1..5] $ \indx -> do изјаве

ili da svakim novim izdanjem rezultat bude kao u listi

statements_result_list <- forM [1..5] $ \indx -> do изјаве

Ali, ako želite da sačuvate prostor [1..5] u listi, više autentična forLoop_ konstrukcija može se definisati kao

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

I koristiti se kao:

  forLoopM_ (0::Int) (< len) (+1) $ \indx -> do -- било шта са индексом

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

uredi
FOR Broj := 1 TO 5 DO
  (* изјава *)
END

Imajte na umu da je u originalnom jeziku Oberon for petlja izostavljena u korist generalnog konstrukta Oberon petlje. For petlja je ponovo uvedena u Oberon 2.

1991: Python

uredi
for broj in range(1, 6): # опсег (1, 6) даје вредност од 1 до 5 (али не 6)
  # изјаве

1993: AppleScript

uredi
repeat with i from 1 to 5
	-- изјаве
	log i
end repeat

Takođe možete proći kroz listu stavki, slično onome što možete da uradite sa nizovima y drugim jezicima:

set x to {1, "вафли", "сланина", 5.1, false}
repeat with i in x
	log i
end repeat

Takođe možete koristiti "exit repeat" da izađete iz petlje u bilo kom trenutku. Za razliku od drugih jezika, AppleScript trenutno nema nikakvu naredbu da nastavi do sledeće naredbe u petlji.

1993: Lua

uredi
for i = почетак, крај, интервал do
     -- изјаве
end

Dakle, ovaj kod

for i = 1, 5, 2 do
     print(i)
end

će ispisati:

1 3 5

For petlje mogu takođe da idu kroz tabelu korišćenjem

ipairs()

da brojčano ponovi kroz nizove i

pairs()

da nasumice prelazili preko rečnika.

Generisana for petlja pravi zatvaranja:

for ime, telefon, adresa in kontakti() do
     -- kontakti() морају бити понављајућа функција
end

Skript sintaksa

uredi

Jednostavan indeks petlje:

for (i = 1; i <= 5; i++) {
	// изјаве
}

Koristeći niz:

for (i in [1,2,3,4,5]) {
	// изјаве
}

Korišćenjem "liste" vrednosti niski:

loop index="i" list="1;2,3;4,5" delimiters=",;" {
	// изјаве
}

Tag sintaksa

uredi

Jednostavan indeks petlje:

<cfloop index="i" from="1" to="5">
	<!--- изјаве --->
</cfloop>

Koristeći niz:

<cfloop index="i" array="#[1,2,3,4,5]#">
	<!--- изјаве --->
</cfloop>

Korišćenjem "liste" vrednosti niski:

<cfloop index="i" list="1;2,3;4,5" delimiters=",;">
	<!--- изјаве --->
</cfloop>

1995:Java

uredi
for (int i = 0; i < 5; i++) {
    //обавља функције у оквиру петље;
    //може користити изјаву 'break;' да брзо изађе из петље
    //може користити изјаву 'continue;' да прескочи тренутни корак 
}

Za produženu for petlju, pogledajte Foreach petlju

1995:JavaScript

uredi

JavaScript podržava S stil "troizraznih" petlji. Вreak i continue izjave su podržane u petlji.

for (var i = 0; i < 5; i++) {
    // ...
}

Alternativno, moguće je ponoviti preko svih ključeva jednog niza.

for (var key in array) { // такође ради са assoc. arrays
  // користи array[key]
  ...
}

1995: PHP

uredi
for ($i = 0; $i <= 5; $i++)
{
  for ($j = 0; $j <= $i; $j++)
  {
    echo "*";
  }
  echo "<br />";
}

1995: Ruby

uredi
for broj in 1..5
  # изјаве
end

5.times do |broj| # број се понавља од 0 до 4
  # изјаве
end

1.upto(5) do |broj|
  # изјаве
end

1996: OCaml

uredi

Pogledajte sintaksu izraza.[6]

 (* for_изјава := "for" ident '='  expr  ( "to" ∣  "downto" ) expr "do" expr "done" *)

for i = 1 to 5 do
    (* изјаве *)
  done ;;

for j = 5 downto 0 do
    (* изјаве *)
  done ;;

1998: ActionScript 3

uredi
for (var broj:uint = 1; broj <= 5; broj++){
  //изјава;
}

Implementacija u Interpretiranim programskim jezicima

uredi

U interpretiranim programskim jezicima, for petlje mogu biti realizovane na više načina. Često su for petlje direktno prevedene na asembler kao upoređujuća uputstva i uputstva uslovnih skokova. Međutim, to nije uvek tako. U nekim tumačima programskih jezika, for petlje su samo prevedene na while petlje.[7] Na primer, uzmite sledeći Mint/Horchata kod:

for i = 0; i < 100; i++
    print i
end

за сваку ставку секвенце
    штампај ставку
крај

/* 'Преведена традиционална for петља' */
i = 0
while i < 100
    print i
    i++
end

/* 'Преведена for each петља' */
SYSTEM_VAR_0000 = 0
while SYSTEM_VAR_0000 < sekvenca.length()
    stavka = sekvenca[SYSTEM_VAR_0000]
    print stavka
    SYSTEM_VAR_0000++
end

Vidi još

uredi

Reference

uredi
  1. ^ „C++ For Loop”. 
  2. ^ „For loops in C++”. 
  3. ^ „Compiler Warning (level 4) C4127”. Microsoft. Pristupljeno 29. 6. 2011. 
  4. ^ PostScript Language Reference. Addison-Wesley Publishing Company. str. 596. ISBN 978-0-201-37922-8. 
  5. ^ „PostScript Tutorial - Loops”. 
  6. ^ „OCaml expression syntax”. Arhivirano iz originala 12. 04. 2013. g. Pristupljeno 02. 11. 2015. 
  7. ^ „Computer Science 61B: Data Structures and Algorithms in Java 6 - For Loops”. Arhivirano iz originala 20. 03. 2015. g. Pristupljeno 02. 11. 2015. 

Literatura

uredi