stringtranslate.com

Для цикла

Блок-схема следующего кода цикла:
для ( я = 0 ; я < 5 ; я ++ ) printf ( "*" );        
В результате цикла будут напечатаны пять звездочек.

В информатике цикл for или цикл for — это оператор потока управления для указания итерации . В частности, цикл for функционирует, многократно выполняя раздел кода до тех пор, пока не будет выполнено определенное условие.

Циклы for состоят из двух частей: заголовка и тела. Заголовок определяет итерацию, а тело — это код, выполняемый один раз за итерацию. Заголовок часто объявляет явный счетчик цикла или переменную цикла . Это позволяет телу знать, какая итерация выполняется. Циклы for обычно используются, когда число итераций известно до входа в цикл. Циклы for можно рассматривать как сокращения для циклов while , которые увеличивают и проверяют переменную цикла.

Для указания использования цикла for используются различные ключевые слова: потомки ALGOL используют " for ", а потомки Fortran используют " do ". Существуют и другие возможности, например, COBOL , который использует .PERFORM VARYING

Название for-loop происходит от слова for. For используется как зарезервированное слово (или ключевое слово) во многих языках программирования для введения for-loop. Термин в английском языке относится к ALGOL 58 и был популярен в ALGOL 60. Это прямой перевод более раннего немецкого für и использовался в Superplan (1949–1951) Хайнцем Рутисхаузером . Рутисхаузер принимал участие в определении ALGOL 58 и ALGOL 60. [1] Тело цикла выполняется «для» заданных значений переменной цикла. Это более явно в версиях оператора for на ALGOL , где можно указать список возможных значений и приращений.

В Fortran и PL/I ключевое слово DO используется для одного и того же и называется do-loop ; это отличается от цикла do while .

ДЛЯ

Для иллюстрации цикла, от i=0 до i=2, в результате чего data1=200

Оператор цикла for доступен в большинстве императивных языков программирования. Даже игнорируя незначительные различия в синтаксисе , существует множество различий в том, как работают эти операторы и какой уровень выразительности они поддерживают. Обычно циклы for попадают в одну из четырех категорий:

Традиционные циклы for

Цикл for в таких языках, как ALGOL , Simula , BASIC , Pascal , Modula , Oberon , Ada , MATLAB , OCaml , F# и т. д., требует управляющей переменной с начальными и конечными значениями, которая выглядит примерно так:

для i = от первого до последнего оператора do (* или просто *) для i = от первого до последнего оператора do            

В зависимости от языка вместо знака равенства может использоваться явный знак присваивания (а некоторые языки требуют этого слова даже в числовом случае). Также может быть включено необязательное значение шага (инкремент или декремент ≠ 1), хотя точный синтаксис, используемый для этого, немного отличается в разных языках. Некоторые языки требуют отдельного объявления управляющей переменной, некоторые — нет.int

Другая форма была популяризирована языком C. Она требует 3 частей: инициализация ( вариант цикла ), условие и переход к следующей итерации. Все эти три части являются необязательными. [2] Этот тип «циклов с точкой с запятой» пришел из языка программирования B и был первоначально изобретен Стивеном Джонсоном . [3]

В части инициализации объявляются все необходимые переменные (и им обычно присваиваются значения). Если объявляется несколько переменных, все они должны быть одного типа. Часть условия проверяет определенное условие и выходит из цикла, если оно ложно, даже если цикл никогда не выполняется. Если условие истинно, то выполняются строки кода внутри цикла. Переход к следующей части итерации выполняется ровно один раз каждый раз, когда цикл заканчивается. Затем цикл повторяется, если условие оценивается как истинное.

Вот пример традиционного цикла for в стиле C в Java .

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

Эти циклы также иногда называют числовыми циклами for в отличие от циклов foreach (см. ниже).

Циклы for на основе итераторов

Этот тип цикла for является обобщением типа числового диапазона цикла for, поскольку он позволяет перечислять наборы элементов, отличные от числовых последовательностей. Обычно он характеризуется использованием неявного или явного итератора , в котором переменная цикла принимает каждое из значений в последовательности или другой коллекции данных. Типичный пример на Python :

для  элемента  в some_iterable_object : do_something () do_something_else ( )    

Где some_iterable_objectлибо коллекция данных, которая поддерживает неявную итерацию (например, список имен сотрудников), либо может быть итератором. Некоторые языки имеют это в дополнение к другому синтаксису цикла for; в частности, PHP имеет этот тип цикла под именем for each, а также цикл for из трех выражений (см. ниже) под именем for.

Векторизованные циклы for

Некоторые языки предлагают цикл for, который действует так, как будто обрабатывает все итерации параллельно , например, for allключевое слово в Fortran 95 , которое имеет интерпретацию, что все выражения правой стороны вычисляются до того, как будут сделаны какие-либо назначения, в отличие от явной формы итерации. Например, в forоператоре в следующем фрагменте псевдокода при вычислении нового значения для A(i), за исключением первого (с i = 2), ссылка на A(i - 1)получит новое значение, которое было помещено туда на предыдущем шаге. В for allверсии, однако, каждое вычисление относится только к исходному, неизмененному A.

для i := 2 : N - 1 сделать A(i) := [A(i - 1) + A(i) + A(i + 1)] / 3; следующий i; для всех i := 2 : N - 1 сделать A(i) := [A(i - 1) + A(i) + A(i + 1)] / 3;

Разница может быть существенной.

Некоторые языки (например, PL/I, Fortran 95) также предлагают операторы присваивания массива, которые позволяют опустить многие циклы for. Таким образом, псевдокод, такой как A:= 0;установит все элементы массива A в ноль, независимо от его размера или размерности. Пример цикла может быть отображен как

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

Однако в руководстве по компилятору может быть неясно, будет ли это представлено в стиле цикла for, цикла for-all или чего-то еще.

Составные циклы for

Введенный в ALGOL 68 и впоследствии PL/I, этот подход позволяет объединить итерацию цикла с проверкой, как в

для i := 1 : N пока A(i) > 0 делать и т.д.

То есть переменной цикла i присваивается значение , и только если выражение while истинно , будет выполнено тело цикла. Если результат ложный, выполнение цикла for останавливается. При условии, что значение переменной цикла определено после завершения цикла, то приведенный выше оператор найдет первый неположительный элемент в массиве A (а если такового нет, его значение будет равно N + 1 ), или, с подходящими вариациями, первый непустой символ в строке и т. д.

Счетчики циклов

В программировании на компьютере счетчик циклов — это управляющая переменная, которая управляет итерациями цикла ( конструкция языка программирования на компьютере ). Она так названа, потому что большинство применений этой конструкции приводит к тому, что переменная принимает диапазон целочисленных значений в некоторых упорядоченных последовательностях (например, начиная с 0 и заканчивая 10 с шагом 1)

Счетчики цикла изменяются с каждой итерацией цикла, предоставляя уникальное значение для каждой итерации. Счетчик цикла используется для принятия решения о том, когда цикл должен завершиться, и для продолжения потока программы к следующей инструкции после цикла.

Распространенное соглашение об именовании идентификаторов заключается в том, что для счетчика цикла используются имена переменных i , j и k (и так далее, если необходимо), где i будет самым внешним циклом, j — следующим внутренним циклом и т. д. Некоторые программисты также используют обратный порядок. Общепризнано, что этот стиль возник из раннего программирования на Фортране [ требуется ссылка ] , где эти имена переменных, начинающиеся с этих букв, неявно объявлялись как имеющие целочисленный тип, и поэтому были очевидным выбором для счетчиков циклов, которые требовались только временно. Практика восходит еще к математической нотации , где индексами для сумм и умножений часто являются i , j и т. д. Вариант соглашения заключается в использовании дублирующихся букв для индекса, ii , jj и kk , поскольку это упрощает поиск и поиск-замену, чем использование одной буквы. [4]

Пример

Пример кода на языке C, включающего вложенные циклы for, где переменными счетчика цикла являются i и j :

для ( i = 0 ; i < 100 ; i ++ ) { для ( j = i ; j < 10 ; j ++ ) { некоторая_функция ( i , j ); } }                    

Циклы в языке C также можно использовать для печати слова в обратном порядке. Например:

для ( я = 0 ; я < 6 ; я ++ ) { шарф ( "%c" , &a a [ я ]); } для ( я = 4 ; я >= 0 ; я -- ) { printf ( "%c" , a [ я ]); }                    

Здесь, если входные данные равны apple, то выходные данные будут равны elppa.

Дополнительная семантика и конструкции

Использовать как бесконечные циклы

Этот цикл for в стиле C обычно является источником бесконечного цикла , поскольку основные шаги итерации полностью контролируются программистом. Когда подразумеваются бесконечные циклы, этот тип цикла for может использоваться (с пустыми выражениями), например:

for (;;) //тело цикла  

Этот стиль используется вместо бесконечных while (1)циклов, чтобы избежать предупреждения о преобразовании типов в некоторых компиляторах C/C++. [5] Некоторые программисты предпочитают более лаконичную for (;;)форму семантически эквивалентной, но более подробной while (true)форме.

Ранний выход и продолжение

Некоторые языки также могут предоставлять другие вспомогательные операторы, которые при наличии могут изменять ход выполнения итерации цикла for. Среди них распространены операторы break и continue , встречающиеся в C и его производных. Оператор break немедленно завершает самый внутренний цикл при выполнении. Оператор continue сразу же перейдет к следующей итерации без дальнейшего продвижения по телу цикла для текущей итерации. Оператор for также завершается, когда выполняется оператор break, goto или return в теле оператора. [Wells] Другие языки могут иметь похожие операторы или иным образом предоставлять средства для изменения хода выполнения цикла for; например, в Fortran 95:

DO I = 1 , N операторов ! Выполняется для всех значений "I", вплоть до катастрофы, если таковая имеется. IF ( нехорошо ) CYCLE ! Пропустить это значение "I" и продолжить со следующим. Операторы ! Выполняется только там, где преобладает добро . IF ( катастрофа ) EXIT ! Прекратить цикл. Операторы ! Пока хорошо и, нет катастрофы. END DO ! Должны соответствовать "DO".             

Некоторые языки предлагают дополнительные возможности, такие как присвоение имен различным операторам цикла, так что при наличии нескольких вложенных циклов не возникает сомнений относительно того, какой цикл задействован. Например, Fortran 95:

X1 : DO I = 1 , N операторов X2 : DO J = 1 , M операторов IF ( проблема ) CYCLE X1 операторы END DO X2 операторы END DO X1                

Таким образом, когда во внутреннем цикле обнаруживается "проблема", CYCLE X1 (не X2) означает, что переход будет на следующую итерацию для I, а не J. Компилятор также будет проверять, что каждый END DO имеет соответствующую метку для своей позиции: это не просто помощь в документировании. Программист все равно должен правильно закодировать проблему, но некоторые возможные ошибки будут заблокированы.

Область действия и семантика переменной цикла

Различные языки определяют разные правила для того, какое значение будет хранить переменная цикла при завершении цикла, и некоторые действительно считают, что она «становится неопределенной». Это позволяет компилятору генерировать код, который оставляет любое значение в переменной цикла или, возможно, даже оставляет ее неизменной, поскольку значение цикла хранилось в регистре и никогда не сохранялось в памяти. Фактическое поведение может даже различаться в зависимости от настроек оптимизации компилятора, как в случае с компилятором Honeywell Fortran66.

В некоторых языках (не C или C++ ) переменная цикла неизменяема в пределах области действия тела цикла, и любая попытка изменить ее значение рассматривается как семантическая ошибка. Такие изменения иногда являются следствием ошибки программиста, которую очень трудно идентифицировать после ее внесения. Однако компилятор, скорее всего, обнаружит только явные изменения. Ситуации, когда адрес переменной цикла передается в качестве аргумента подпрограмме , очень затрудняют проверку, поскольку поведение подпрограммы в общем случае неизвестно компилятору. Несколько примеров в стиле Fortran:

DO I = 1 , N I = 7 ! Явная корректировка переменной цикла. Вероятна жалоба компилятора. Z = ADJUST ( I ) ! Функция "ADJUST" может изменить "I" с неопределенным эффектом. Обычные операторы ! Память может исчезнуть, а "I" — это переменная цикла. PRINT ( A ( I ), B ( I ), I = 1 , N , 2 ) ! Неявный цикл for для печати нечетных элементов массивов A и B, повторное использование "I"... PRINT I ! Какое значение будет представлено? END DO ! Сколько раз будет выполнен цикл?                     

Обычный подход заключается в вычислении количества итераций в начале цикла (с особым вниманием к переполнению, как в for i:= 0: 65535 do ... ;шестнадцатибитной целочисленной арифметике) и с каждой итерацией уменьшать это количество, одновременно корректируя значение I : результаты двойного подсчета. Однако корректировка значения I в цикле не изменит количество выполненных итераций.

Тем не менее, другая возможность заключается в том, что сгенерированный код может использовать вспомогательную переменную в качестве переменной цикла, возможно, хранящейся в машинном регистре, значение которой может или не может быть скопировано в I на каждой итерации. Опять же, изменения I не повлияют на управление циклом, но теперь возможна дизъюнкция: внутри цикла ссылки на значение I могут быть ссылками на (возможно измененное) текущее значение I или на вспомогательную переменную (сохраненную от неправильной модификации), и запутанные результаты гарантированы. Например, внутри цикла ссылка на элемент I массива, скорее всего, будет использовать вспомогательную переменную (особенно если она хранится в машинном регистре), но если I является параметром некоторой процедуры (например, оператора print для раскрытия ее значения), то вместо этого, скорее всего, это будет ссылка на правильную переменную I. Лучше избегать таких возможностей.

Корректировка границ

Так же, как переменная индекса может быть изменена в цикле for, так же могут быть изменены ее границы и направление. Но с неопределенным эффектом. Компилятор может предотвратить такие попытки, они могут не иметь никакого эффекта или даже работать правильно - хотя многие заявят, что делать так было бы неправильно. Рассмотрим такое утверждение, как

для i := первый : последний : шаг сделать A(i) := A(i) / A(последний);

Если бы подход к составлению такого цикла заключался в оценке first , last и step и вычислении количества итераций с помощью чего-то вроде одного раза только в начале, то если бы эти элементы были простыми переменными и их значения каким-то образом корректировались во время итераций, это не оказало бы никакого влияния на количество итераций, даже если бы элемент, выбранный для деления, изменился.(last - first)/stepA(last)

Список диапазонов значений

PL/I и ALGOL 68 допускают циклы, в которых переменная цикла итерируется по списку диапазонов значений вместо одного диапазона. Следующий пример PL/I выполнит цикл с шестью значениями i: 1, 7, 12, 13, 14, 15:

do  i = 1 , 7 , 12 to 15 ; /*утверждения*/ конец ;       

Эквивалентность с циклами while

Цикл for обычно эквивалентен циклу while:

факториал := 1 для счетчика от 2 до 5 факториал := факториал * счетчиксчетчик:= счетчик - 1счетчик печати + "! равно " + факториал

Эквивалентно:

факториал := 1счетчик := 1 пока счетчик < 5 счетчик := счетчик + 1 факториал := факториал * счетчиксчетчик печати + "! равно " + факториал

Как показывают выходные данные переменных.

Хронологияцикл forсинтаксис в различных языках программирования

Учитывая действие, которое должно быть повторено, например, пять раз, циклы for разных языков будут написаны по-разному. Синтаксис цикла for из трех выражений практически идентичен во всех языках, где он есть, после учета различных стилей завершения блока и т. д.

1957: ФОРТРАН

Эквивалентом цикла for в Фортране является цикл DO , использующий ключевое слово do вместо for. Синтаксис цикла DO в Фортране следующий:

   DO метка счетчик = первый , последний , шаг операторы метка оператор          

Следующие два примера ведут себя эквивалентно циклу for с тремя аргументами в других языках, инициализируя переменную счетчика значением 1, увеличивая ее на 1 на каждой итерации цикла и останавливаясь на пяти аргументах (включительно).

   DO 9 , СЧЕТЧИК = 1 , 5 , 1 ЗАПИСЬ ( 6 , 8 ) СЧЕТЧИК  8 ФОРМАТ ( I2 )  9 ПРОДОЛЖИТЬ                

В Fortran 77 (или более поздней версии) это можно также записать так:

сделать счетчик = 1 , 5 написать ( * , '(i2)' ) счетчик конец сделать      

Часть шага может быть опущена, если шаг один. Пример:

* Пример цикла DO. ПРОГРАММА 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                                      

Пробелы не имеют значения в операторах Fortran фиксированной формы, поэтому SUM SQ — это то же самое, что и SUMSQ . В современном стиле Fortran свободной формы пробелы имеют значение.

В Fortran 90 оператор GO TO можно обойти, используя оператор EXIT .

* Пример цикла DO. Программа main неявный none         целое число :: суммы целое число :: i        суммы = 0 сделать i = 1 , 9999999 если ( суммы > 100 0.0 ) выйти суммы = суммы + i ** 2 конец сделать печать * , суммы                                 конец программы

1958: АЛГОЛ

В ALGOL 58 был введен forоператор, использующий форму Суперплана:

FOR Идентификатор = База ( Разница ) Предел

Например, чтобы напечатать число от 0 до 10 с шагом 1:

ДЛЯ x = 0 (1) 10 НАЧАЛОПЕЧАТЬ (FL) = x КОНЕЦ

1960: КОБОЛ

COBOL был формализован в конце 1959 года и имел много уточнений. Он использует глагол PERFORM, который имеет много опций. Первоначально все циклы должны были быть вне строки с итерируемым кодом, занимающим отдельный абзац. Игнорируя необходимость объявления и инициализации переменных, эквивалентом цикла for в COBOL будет.

 ВЫПОЛНЯЙТЕ SQ-ПРОЦЕДУРУ, ИЗМЕНЯЯ I ОТ 1 НА 1, ПОКА I > 1000          ПРОЦЕДУРА SQ-ДОБАВЛЕНИЯ I ** 2 К SUM-SQ .    

В 1980-х годах добавление встроенных циклов и структурированных программных операторов, таких как END-PERFORM, привело к появлению цикла for с более привычной структурой.

 ВЫПОЛНИТЬ ИЗМЕНЯЮЩУЮСЯ I ОТ 1 НА 1 ДО ТЕХ ПОР, ПОКА I НЕ БУДЕТ > 1000 ДОБАВИТЬ I ** 2 К СУММЕ-КВ . КОНЕЦ-ВЫПОЛНИТЬ            

Если глагол PERFORM имеет необязательное предложение TEST AFTER, результирующий цикл немного отличается: тело цикла выполняется как минимум один раз, перед любой проверкой.

1964: ОСНОВНОЙ

В BASIC цикл иногда называется циклом for-next .

10 REM ЭТОТ ЦИКЛ FOR ПЕЧАТАЕТ НЕЧЕТНЫЕ ЧИСЛА ОТ 1 ДО 15 20 ДЛЯ I = ОТ 1 ДО 15 ШАГ 2 30 ПЕЧАТЬ I 40 ДАЛЕЕ I             

Маркер конца цикла указывает имя индексной переменной, которое должно соответствовать имени индексной переменной в начале цикла for. Некоторые языки (PL/I, Fortran 95 и более поздние) допускают метку оператора в начале цикла for, которая может быть сопоставлена ​​компилятором с тем же текстом в соответствующем операторе конца цикла. Fortran также допускает операторы EXITи CYCLEдля именования этого текста; в гнезде циклов это дает понять, какой цикл предполагается. Однако в этих языках метки должны быть уникальными, поэтому последовательные циклы, включающие одну и ту же индексную переменную, не могут использовать один и тот же текст, а метка не может совпадать с именем переменной, например, индексной переменной для цикла.

1964: ПЛ/И

do  counter = 1 to 5 by 1 ; /* "by 1" - значение по умолчанию, если не указано иное */ /*statements*/ ; end ;         

Оператор LEAVE может использоваться для выхода из цикла. Циклы могут быть помечены , и оператор leave может оставить определенный помеченный цикл в группе вложенных циклов. Некоторые диалекты PL/I включают оператор ITERATE для завершения текущей итерации цикла и начала следующей.

1968: АЛГОЛ 68

В ALGOL 68 есть то, что считалось универсальным циклом, полный синтаксис которого выглядит так:

ДЛЯ i ОТ 1 НА 2 ДО 3 ПОКА i≠4 ДЕЛАТЬ ~ OD

Далее, диапазон единичной итерации может быть заменен списком таких диапазонов. Есть несколько необычных аспектов конструкции

INT сумма кв := 0;ДЛЯ Я ПОКА print(("So far:", i, new line)); # Вставлено для целей трассировки. # сумма кв ≠ 70↑2 # Это тест для WHILE #ДЕЛАТЬ сумма кв +:= i↑2ОД

Последующие расширения стандарта ALGOL 68 позволили toзаменить синтаксический элемент на uptoи downtoдобиться небольшой оптимизации. Те же компиляторы также включили:

until
для позднего завершения цикла.
foreach
для параллельной работы с массивами .

1970: Паскаль

для Счетчика := от 1 до 5 do (*оператор*) ;      

Декремент (обратный отсчет) осуществляется с использованием downtoключевого слова вместо to, например:

для Counter := 5 вниз к 1 do (*statement*) ;       

Числовой диапазон цикла for варьируется несколько больше.

1972: С, С++

для ( инициализация ; условие ; инкремент / декремент ) оператор    

Оператор часто представляет собой блок-оператор; примером этого может служить:

//Использование циклов for для сложения чисел 1 - 5 int sum = 0 ; for ( int i = 1 ; i <= 5 ; ++ i ) { sum += i ; }               

Публикация ISO/IEC 9899:1999 (широко известная как C99 ) также допускает начальные объявления в forциклах. Все три раздела в цикле for являются необязательными, а пустое условие эквивалентно true.

1972: Разговоры

1  до:  5  сделать: [ : счетчик  |  "утверждения" ]

В отличие от других языков, в Smalltalk цикл for не является языковой конструкцией , а определяется в классе Number как метод с двумя параметрами: конечным значением и замыканием , использующим self в качестве начального значения.

1980: Ада

для  Счетчика  в  цикле  1..5  - операторы заканчивают цикл ;   

Оператор выхода может использоваться для выхода из цикла. Циклы могут быть помечены, и выход может оставить специально помеченный цикл в группе вложенных циклов:

Подсчет :  для  счетчика  в  цикле  1..5  Треугольник : для вторичного_индекса в цикле 2..Счетчик операторы выходят Подсчет ; операторы заканчивают цикл Треугольник ; конец цикла Подсчет ;                   

1980: Мейпл

Maple имеет две формы цикла for, одна для итерации по диапазону значений, а другая для итерации по содержимому контейнера. Форма диапазона значений выглядит следующим образом:

для  i  от  f  по  b  до  t  пока  w  do  # тело цикла od ;

Все части, кроме doи , odявляются необязательными. Часть, если она присутствует, должна быть первой. Остальные части ( , , , ) могут появляться в любом порядке. for Ifrom fby bto twhile w

Итерация по контейнеру выполняется с использованием следующей формы цикла:

for  e  in  c  while  w  do  # тело цикла od ;

В предложении указывается контейнер, который может быть списком, набором, суммой, произведением, неоцененной функцией, массивом или объектом, реализующим итератор. in c

Цикл for может быть завершен с помощью od, end, или end do.

1982: Максима CAS

В Maxima CAS можно использовать также целочисленные значения:

для x : 0.5 шаг 0.1 через 0.9 do /* "Сделать что-нибудь с x" */       

1982: Постскриптум

Цикл for, записанный как [initial] [increment] [limit] { ... } forинициализирует внутреннюю переменную и выполняет тело до тех пор, пока внутренняя переменная не больше предела (или не меньше, если приращение отрицательное) и в конце каждой итерации увеличивает внутреннюю переменную. Перед каждой итерацией значение внутренней переменной помещается в стек. [6]

1  1  6  { ЗАЯВЛЕНИЯ }  для

Также существует простой цикл повторения. Цикл повторения, записанный как X { ... } repeat, повторяет тело ровно X раз. [7]

5  {  ЗАЯВЛЕНИЯ  }  повторить

1983: Ада 83 и выше

Процедура  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: МАТЛАБ

для n = 1 : 5 -- утверждения заканчиваются     

После цикла nв этом примере будет 5.

Поскольку iиспользуется для мнимой единицы , ее использование в качестве переменной цикла не рекомендуется.

1987: Перл

for ( $counter = 1 ; $counter <= 5 ; $counter ++ ) { # неявно или предопределенная переменная # операторы; } for ( my $counter = 1 ; $counter <= 5 ; $counter ++ ) { # переменная, приватная для цикла # операторы; } for ( 1 .. 5 ) { # переменная, неявно вызванная $_; 1..5 создает список из этих 5 элементов # операторы; } оператор for 1 .. 5 ; # почти то же самое (только 1 оператор) с естественным порядком языка for my $counter ( 1 .. 5 ) { # переменная, приватная для цикла # операторы; }                                  

« Есть больше одного способа сделать это » — девиз программирования на Perl.

1988: Математика

Конструкция, соответствующая циклу for большинства других языков, в системе Mathematica называется Do.

Сделай [ ф [ х ] , { х , 0 , 1 , 0.1 } ]    

В Mathematica также есть конструкция For, которая имитирует цикл for языков типа C.

Для [ x = 0 , x < = 1 , x + = 0.1 , f [ x ] ]         

1989: Баш

# первая форма for  i in 1 2 3 4 5 do # должна быть хотя бы одна команда в цикле echo $i # просто вывести значение i done          
# вторая форма for (( i = 1 ; i < = 5 ; i++ )) do # должна быть хотя бы одна команда в цикле echo $i # просто выведите значение i done             

Пустой цикл (т. е. цикл без команд между doи done) является синтаксической ошибкой. Если бы указанные выше циклы содержали только комментарии, выполнение привело бы к сообщению "синтаксическая ошибка около неожиданного токена 'done'".

1990: Хаскелл

Встроенный императив forM_ отображает монадическое выражение в список, как

forM_ [ 1 .. 5 ] $ \ indx -> do операторы      

или получить каждый результат итерации в виде списка в

statements_result_list <- forM [ 1 .. 5 ] $ \ indx -> do операторы        

Но для экономии места в списке [1..5] можно определить более аутентичную монадическую конструкцию forLoop_ как

импортировать Control.Monad как M   forLoopM_ :: Monad m => a -> ( a -> Bool ) -> ( a -> a ) -> ( a -> m () ) -> m () forLoopM_ indx prop incr f = do f index M . when ( prop next ) $ forLoopM_ next prop incr f где next = incur index                                           

и используется как:

 forLoopM_ ( 0 :: Int ) ( < len ) ( + 1 ) $ \ indx -> do -- что угодно с индексом         

1991: Оберон-2, Оберон-07, Компонентный Паскаль

FOR  Counter :=  1  TO  5  DO  (* последовательность операторов *) END

В оригинальном языке Oberon цикл for был опущен в пользу более общей конструкции цикла Oberon. Цикл for был вновь введен в Oberon-2.

1991: Питон

В Python нет классического цикла for, вместо этого foreachцикл используется для итерации по выходным данным встроенной range()функции, которая возвращает итерируемую последовательность целых чисел.

for  i  in  range ( 1 ,  6 ):  # дает i значения от 1 до 5 включительно (но не 6)  # операторы  print ( i ) # если нам нужно 6, мы должны сделать следующее for  i  in  range ( 1 ,  6  +  1 ):  # дает i значения от 1 до 6  # операторы  print ( i )

Использование range(6)запустит цикл от 0 до 5.

1993: AppleScript

повторите  с  i  от  1  до  5 -- операторы log  i конец  повтора

Он также может выполнять итерацию по списку элементов, подобно тому, как это можно делать с массивами в других языках:

установить  x  в  { 1 ,  "вафли" ,  "бекон" ,  5.1 ,  false } повторить  с  i  в  x log  i конец  повторить

A exit repeatтакже может быть использован для выхода из цикла в любое время. В отличие от других языков, AppleScript в настоящее время не имеет команды для продолжения следующей итерации цикла.

1993: Кристалл

для  i  =  начало ,  остановка ,  интервал  do  -- операторы конец

Итак, этот код

для  i  =  1 ,  5 ,  2  вывести  ( i ) конец

напечатает:

1  3  5

Циклы for также могут проходить по таблице, используя

ipairs ()

для численной итерации по массивам и

пары ()

для случайного перебора словарей.

Общий цикл for, использующий замыкания:

для  имени ,  телефона и  адреса в contacts  ( ) do -- contacts() должна быть функцией-итератором end    

1995: Язык разметки ColdFusion (CFML)

Синтаксис скрипта

Простой индексный цикл:

для  ( i  =  1 ;  i  <=  5 ;  i ++ )  { // операторы }

Использование массива:

для  ( i  in  [ 1 , 2 , 3 , 4 , 5 ])  { // операторы }

Использование списка строковых значений:

 индекс цикла = "i"  список = "1;2,3;4,5"  разделители = ",;"  { // операторы }

Приведенный выше listпример доступен только на диалекте CFML, используемом Люси и Райло .

Синтаксис тега

Простой индексный цикл:

<cfloop  index = "i"  from = "1"  to = "5" > <!--- операторы ---> </cfloop>

Использование массива:

<cfloop  index = "i"  array = " #[1,2,3,4,5]# " > <!--- операторы ---> </cfloop>

Использование «списка» строковых значений:

<cfloop  index = "i"  list = "1;2,3;4,5"  delimiters = ",;" > <!--- операторы ---> </cfloop>

1995: Ява

for ( int i = 0 ; i < 5 ; i ++ ) { //выполняем функции внутри цикла; //можно использовать оператор 'break;' для раннего выхода; //можно использовать оператор 'continue;' для пропуска текущей итерации }            

Для расширенного цикла for см. Цикл Foreach § Java .

1995: JavaScript

JavaScript поддерживает циклы "трех выражений" в стиле C. Операторы breakи continueподдерживаются внутри циклов.

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

В качестве альтернативы можно выполнить итерацию по всем ключам массива.

for ( var key in array ) { // также работает для ассоциативных массивов // используйте array[key] ... }        

1995: PHP

Это распечатает треугольник *

для  ( $i  =  0 ;  $i  <=  5 ;  $i ++ )  {  для  ( $j  =  0 ;  $j  <=  $i ;  $j ++ )  {  echo  "*" ;  }  echo  "<br /> \n " ; }

1995: Руби

для счетчика в 1 .. 5 # операторы заканчиваются     5 . times do | counter | # counter выполняет итерации от 0 до 4 # операторы заканчиваются    1. до ( 5 ) сделать | счетчик | # операторы конец   

В Ruby существует несколько возможных синтаксисов, включая приведенные выше примеры.

1996: OCaml

См. синтаксис выражения. [8]

 (* for_statement:= "for" ident '=' expr ( "to" ∣ "down to" ) expr "do" expr "done" *)для  i  =  от 1  до  5  сделать  (* операторы *)  сделано  ;;для  j  =  5  вниз  до  0  сделать  (* операторы *)  сделано  ;;

1998: ActionScript 3

для ( var counter : uint = 1 ; counter <= 5 ; counter ++) { // оператор; }         

2008: Малый базовый

Для i = 1 до 10 ' Операторы EndFor      

2008: Ним

В Nim есть foreachцикл типа - и различные операции для создания итераторов. [9]

для i в 5 .. 10 : # операторы      

2009: Вперёд

для i := 0 ; i <= 10 ; i ++ { // операторы }         

2010: Ржавчина

для i в 0 .. 10 { // операторы }     

2012: Джулия

для j = 1 : 10 # операторы заканчиваются    

Смотрите также

Ссылки

  1. ^ Вирт, Никлаус (1973). "Предисловие". Систематическое программирование: Введение . Prentice-Hall. стр. xiii. ISBN 0138803692.
  2. ^ "Циклы For в C++". Изучите C++ .
  3. ^ Томпсон, Кен . VCF East 2019 – Брайан Керниган берет интервью у Кена Томпсона. YouTube . Архивировано из оригинала 12.12.2021 . Получено 16.11.2020 . Я видел версию цикла for с точкой с запятой Джонсона и вставил ее в [B], я ее украл.
  4. ^ http://www.knosof.co.uk/vulnerabilities/loopcntrl.pdf Анализ переменных управления циклом в C
  5. ^ "Предупреждение компилятора (уровень 4) C4127". Microsoft . Получено 29 июня 2011 г. .
  6. ^ Справочник языка PostScript . Addison-Wesley Publishing Company. 1999. стр. 596. ISBN 0-201-37922-8.
  7. ^ «Учебник PostScript — Циклы».
  8. ^ "Синтаксис выражений OCaml". Архивировано из оригинала 2013-04-12 . Получено 2013-03-19 .
  9. ^ https://nim-lang.org/docs/system.html#...i%2CT%2CT ".. итератор"