Из чего состоит цикл – Цикл (программирование) — это… Что такое Цикл (программирование)?

Содержание

Цикл (программирование) - это... Что такое Цикл (программирование)?

У этого термина существуют и другие значения, см. цикл. Пример цикла While.

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

Определения

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

Исполнение любого цикла включает первоначальную инициализацию переменных цикла, проверку условия выхода, исполнение тела цикла и обновление переменной цикла на каждой итерации. Кроме того, большинство языков программирования предоставляют средства для досрочного управления циклом, например, операторы завершения цикла, то есть выхода из цикла независимо от истинности условия выхода (в языке Си — break) и операторы пропуска итерации (в языке Си — continue).

Виды циклов

Безусловные циклы

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

LOOP…END LOOP языка Ада), либо заменяется константным значением (while true do … в Паскале). В языке С используется цикл for(;;) с незаполненными секциями.

Цикл с предусловием

Цикл с предусловием — цикл, который выполняется пока истинно некоторое условие, указанное перед его началом. Это условие проверяется до выполнения тела цикла, поэтому тело может быть не выполнено ни разу (если условие с самого начала ложно). В большинстве процедурных языков программирования реализуется оператором while, отсюда его второе название — while-цикл. На языке Pascal цикл с предусловием имеет следующий вид:

while <условие> do
begin   
  <тело цикла> 
end;

На языке Си:

while(<условие>)
{
   <тело цикла>
}

Цикл с постусловием

Цикл с постусловием — цикл, в котором условие проверяется после выполнения тела цикла. Отсюда следует, что тело всегда выполняется хотя бы один раз. В языке Паскаль этот цикл реализует оператор repeat..until; в Си — do…while.

На языке Pascal цикл с постусловием имеет следующий вид::

repeat
    <тело цикла>
until <условие выхода>

На языке Си:

do
{
    <тело цикла>
}
while(<условие продолжения цикла>)


В трактовке условия цикла с постусловием в разных языках есть различия. В Паскале и языках, произошедших от него, условие такого цикла трактуется как условие выхода (цикл завершается, когда условие истинно, в русской терминологии такие циклы называют ещё «цикл до»), а в Си и его потомках — как условие продолжения (цикл завершается, когда условие ложно, такие циклы иногда называют «цикл пока»).

Цикл с выходом из середины

Цикл с выходом из середины — наиболее общая форма условного цикла. Синтаксически такой цикл оформляется с помощью трёх конструкций: начала цикла, конца цикла и команды выхода из цикла. Конструкция начала маркирует точку программы, в которой начинается тело цикла, конструкция конца — точку, где тело заканчивается. Внутри тела должна присутствовать команда выхода из цикла, при выполнении которой цикл заканчивается и управление передаётся на оператор, следующий за конструкцией конца цикла. Естественно, чтобы цикл выполнился более одного раза, команда выхода должна вызываться не безусловно, а только при выполнении условия выхода из цикла.

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

Легко видеть, что с помощью цикла с выходом из середины можно легко смоделировать и цикл с предусловием (разместив команду выхода в начале тела цикла), и цикл с постусловием (разместив команду выхода в конце тела цикла).

Часть языков программирования содержат специальные конструкции для организации цикла с выходом из середины. Так, в языке Ада для этого используется конструкция LOOP…END LOOP и команда выхода EXIT или EXIT WHEN:

LOOP
  ... Часть тела цикла
  EXIT WHEN <условие выхода>;
  ... Часть тела цикла
  IF <условие выхода> THEN 
    EXIT; 
  END;
  ... Часть тела цикла
END LOOP:

Здесь внутри цикла может быть любое количество команд выхода обоих типов. Сами команды выхода принципиально не различаются, обычно

EXIT WHEN применяют, когда проверяется только условие выхода, а просто EXIT — когда выход из цикла производится в одном из вариантов сложного условного оператора.

В тех языках, где подобных конструкций не предусмотрено, цикл с выходом из середины может быть смоделирован с помощью любого условного цикла и оператора досрочного выхода из цикла (такого, как break в Си, exit в Турбо Паскале т. п.), либо оператора безусловного перехода goto.

Цикл со счётчиком

Цикл со счётчиком — цикл, в котором некоторая переменная изменяет своё значение от заданного начального значения до конечного значения с некоторым шагом, и для каждого значения этой переменной тело цикла выполняется один раз. В большинстве процедурных языков программирования реализуется оператором for, в котором указывается счётчик (так называемая «переменная цикла»), требуемое количество проходов (или граничное значение счётчика) и, возможно, шаг, с которым изменяется счётчик. Например, в языке Оберон-2 такой цикл имеет вид:

 FOR v := b TO e BY s DO
   ... тело цикла
 
END

(здесь v — счётчик, b — начальное значение счётчика, e — граничное значение счётчика, s — шаг).

Неоднозначен вопрос о значении переменной по завершении цикла, в котором эта переменная использовалась как счётчик. Например, если в программе на языке Паскаль встретится конструкция вида:

i := 100;
for i := 0 to 9 do
begin
  ... тело цикла
end;
k := i;

возникает вопрос: какое значение будет в итоге присвоено переменной k: 9, 10, 100, может быть, какое-то другое? А если цикл завершится досрочно? Ответы зависят от того, увеличивается ли значение счётчика после последней итерации и не изменяет ли транслятор это значение дополнительно. Ещё один вопрос: что будет, если внутри цикла счётчику будет явно присвоено новое значение? Различные языки программирования решают данные вопросы по-разному. В некоторых поведение счётчика чётко регламентировано. В других, например, в том же Паскале, стандарт языка не определяет ни конечного значения счётчика, ни последствий его явного изменения в цикле, но не рекомендует изменять счётчик явно и использовать его по завершении цикла без повторной инициализации. Программа на Паскале, игнорирующая эту рекомендацию, может давать разные результаты при выполнении на разных системах и использовании разных трансляторов.

Радикально решён вопрос в языке Ада: счётчик считается описанным в заголовке цикла, и вне его просто не существует. Даже если имя счётчика в программе уже используется, внутри цикла в качестве счётчика используется отдельная переменная. Счётчику запрещено явно присваивать какие бы то ни было значения, он может меняться только внутренним механизмом оператора цикла. В результате конструкция

i := 100;
for i in (0..9) loop
  ... тело цикла
end loop;
k := i;

внешне аналогичная вышеприведённому циклу на Паскале, трактуется однозначно: переменной k будет присвоено значение 100, поскольку переменная i, используемая вне данного цикла, не имеет никакого отношения к счётчику i, который создаётся и изменяется внутри цикла. Подобное обособление счётчика удобно и безопасно: не требуется отдельное описание для него и минимальна вероятность случайных ошибок, связанных со случайным разрушением внешних по отношению к циклу переменных. Если программисту требуется включить в готовый код цикл со счётчиком, то он может не проверять, существует ли переменная с именем, которое он выбрал в качестве счётчика, не добавлять описание нового счётчика в заголовок соответствующей процедуры, не пытаться использовать один из имеющихся, но в данный момент «свободных» счётчиков. Он просто пишет цикл с переменной-счётчиком, имя которой ему удобно, и может быть уверен, что никакой коллизии имён не произойдёт.

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

В некоторых языках, например, Си и других, произошедших от него, цикл for, несмотря на синтаксическую форму цикла со счётчиком, в действительности является циклом с предусловием. То есть в Си конструкция цикла:

for (i = 0; i < 10; ++i)
{
  ... тело цикла 
}

фактически представляет собой другую форму записи конструкции

[1]:

i = 0;
while (i < 10)
{
  ... тело цикла 
  ++i;
}

То есть в конструкции for сначала пишется произвольное предложение инициализации цикла, затем — условие продолжения и, наконец, выполняемая после каждого тела цикла некоторая операция (это не обязательно должно быть изменение счётчика; это может быть правка указателя или какая-нибудь совершенно посторонняя операция). Для языков такого вида вышеописанная проблема решается очень просто: переменная-счётчик ведёт себя совершенно предсказуемо и по завершении цикла сохраняет своё последнее значение.

Совместный цикл

Ещё одним вариантом цикла является цикл, задающий выполнение некоторой операции для объектов из заданного множества, без явного указания порядка перечисления этих объектов. Такие циклы называются совместными (а также циклами по коллекции, циклами просмотра) и представляют собой формальную запись инструкции вида: «Выполнить операцию X для всех элементов, входящих во множество M». Совместный цикл, теоретически, никак не определяет, в каком порядке операция будет применяться к элементам множества, хотя конкретные языки программирования, разумеется, могут задавать конкретный порядок перебора элементов. Произвольность даёт возможность оптимизации исполнения цикла за счёт организации доступа не в заданном программистом, а в наиболее выгодном порядке. При наличии возможности параллельного выполнения нескольких операций возможно даже распараллеливание выполнения совместного цикла, когда одна и та же операция одновременно выполняется на разных вычислительных модулях для разных объектов, при том что логически программа остаётся последовательной.

Совместные циклы имеются в некоторых языках программирования (C#, Eiffel, Java, JavaScript, Perl, Python, PHP, LISP, Tcl и др.) — они позволяют выполнять цикл по всем элементам заданной коллекции объектов. В определении такого цикла требуется указать только коллекцию объектов и переменную, которой в теле цикла будет присвоено значение обрабатываемого в данный момент объекта (или ссылка на него). В различных языках программирования синтаксис оператора различен:

C++:

for (type &item : set) //поддерживается, начиная со стандарта C++11
{
    //использование item
}

C#:

foreach (type item in set) 
{
    //использование item
}

Delphi:

for item in [1..100] do
begin
  //Использование item (Работоспособность кода проверялась в Delphi 2010) 
end;

Perl (строгий порядок "от первого до последнего"):

foreach (@set) 
{
    #использование $_
}
# или
for (@set) 
{
    #использование $_
}
# или
foreach $item (@set) 
{
    #использование $item
}

Eiffel:

across set as cursor loop
    -- использование cursor.item
end

Java:

for (type item : set) 
{
    //использование item
}

JavaScript:

for (txtProperty in objObject)
  {
  /*
  использование:
  objObject [txtProperty]
  */
  }

PHP:

foreach ($arr as $item) {
    /* использование $item*/
}
//или
foreach ($arr as $key=>$value) {
    /* использование значений индекса $key и его значения $value*/
}

Visual Basic.NET:

For Each item As type In set
    'использование item
Next item


Windows PowerShell:

foreach ($item in $set) {
  # операции с $item
}

или

$set | ForEach-Object {
  # операции с $_
}

Python

for item in iterator_instance:
    # использование item

Досрочный выход и пропуск итерации

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

Досрочный выход из цикла

Команда досрочного выхода применяется, когда необходимо прервать выполнение цикла, в котором условие выхода ещё не достигнуто. Такое бывает, например, когда при выполнении тела цикла обнаруживается ошибка, после которой дальнейшая работа цикла не имеет смысла.

Команда досрочного выхода обычно называется EXIT или break, а её действие аналогично действию команды безусловного перехода (goto) на команду, непосредственно следующую за циклом, внутри которого эта команда находится. Так, в языке Си два нижеприведённых цикла работают совершенно одинаково:

// Применение оператора break
while(<условие>) {
  ... операторы
  if (<ошибка>) break;
  ... операторы
}
... продолжение программы
 
// Аналогичный фрагмент без break
while(<условие>) {
  ... операторы
  if (<ошибка>) goto break_label;
  ... операторы 
}
break_label:
... продолжение программы

В обоих случаях, если в теле цикла выполнится условие <ошибка>, будет произведён переход на операторы, обозначенные как «продолжение программы». Таким образом, оператор досрочного выхода из цикла, по сути, просто маскирует безусловный переход, однако использование break предпочтительнее, чем goto, поскольку поведение break чётко задано языком, потенциально менее опасно (нет, например, вероятности ошибиться с положением или названием метки). Кроме того, явный досрочный выход из цикла не нарушает принципов структурного программирования.

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

Пропуск итерации

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

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

int arr[ARRSIZE];
...
// Суммирование отдельно всех и только положительных
// элементов массива arr с применением continue.
int sum_all = 0;
int sum_pos = 0;
for (int i = 0 ; i < ARRSIZE; ++i)
{
    sum_all += arr[i];
    if (arr[i] <= 0) continue;
    sum_pos += arr[i];
}
 
// Аналогичный код c goto
int sum_all = 0;
int sum_pos = 0;
for (int i = 0 ; i < ARRSIZE; ++i)
{
    sum_all += arr[i];
    if (arr[i] <= 0) goto cont_label;
    sum_pos += arr[i];
cont_label:
}

Из второго фрагмента ясно видно, как работает continue: он просто передаёт управление за последнюю команду тела цикла, пропуская выполнение команды суммирования, если очередной элемент массива не удовлетворяет условию. Таким образом, в sum_pos накапливается сумма лишь положительных элементов массива.

Необходимость

С точки зрения структурного программирования команды досрочного выхода из цикла и продолжения итерации являются избыточными, поскольку их действие может быть легко смоделировано чисто структурными средствами. Более того, по мнению ряда теоретиков программирования (в частности, Эдсгера Дейкстры), сам факт использования в программе неструктурных средств, будь то классический безусловный переход или любая из его специализированных форм, таких как break или continue, является свидетельством недостаточно проработанного алгоритма решения задачи.

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

// Досрочный выход из цикла без break
bool flag = false; // флаг досрочного завершения
while(<условие> && !flag) {
  ... операторы
  if (<ошибка>) {
    flag = true;
  } else {
    ... операторы
  }
}
... продолжение программы

Легко убедиться, что фрагмент будет работать аналогично предшествующим, разница лишь в том, что в месте проверки на ошибку вместо непосредственного выхода из цикла устанавливается флаг досрочного выхода, который проверяется позже в штатном условии продолжения цикла. Однако для отказа от команды досрочного выхода пришлось добавить в программу описание флага и вторую ветвь условного оператора, к тому же произошло «размытие» логики программы (решение о досрочном выходе принимается в одном месте, а выполняется в другом). В результате программа не стала ни проще, ни короче, ни понятнее.

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

int arr[ARRSIZE];
...
// Суммирование отдельно всех и только положительных
// элементов массива arr с заменой continue
int sum_all = 0;
int sum_pos = 0;
for (int i = 0 ; i < ARRSIZE; ++i)
{
    sum_all += arr[i];
    if (arr[i] > 0) // Условие заменено на противоположное!
    {
      sum_pos += arr[i];
    }
}

Как видим, достаточно было заменить проверяемое условие на противоположное и поместить заключительную часть тела цикла в условный оператор. Можно заметить, что программа стала короче (за счёт удаления команды пропуска итерации) и одновременно логичнее (из кода непосредственно видно, что суммируются положительные элементы).

Кроме того, использование команды пропуска итерации в цикле с условием (while-цикле) может также спровоцировать неочевидную ошибку: если тело цикла, как это часто бывает, завершается командами изменения переменной (переменных) цикла, то команда пропуска итерации пропустит и эти команды тоже, в результате чего (в зависимости от условия, по которому происходит пропуск) может произойти зацикливание или не соответствующий алгоритму повтор итерации. Так, если заменить в вышеприведённом примере цикл for на while, получится следующее:

int arr[ARRSIZE];
...
int sum_all = 0;
int sum_pos = 0;
int i = 0;
while (i < ARRSIZE) // Цикл внешне аналогичен предыдущему for ...
{
    sum_all += arr[i];
    if (arr[i] <= 0) continue;
    sum_pos += arr[i];
    ++i; // ... но эта команда будет пропущена при выполнении continue 
         // и программа зациклится
}

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

Вложенные циклы

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

Полное число исполнений тела внутреннего цикла не превышает произведения числа итераций внутреннего и всех внешних циклов. Например взяв три вложенных друг в друга цикла, каждый по 10 итераций, получим 10 исполнений тела для внешнего цикла, 100 для цикла второго уровня и 1000 в самом внутреннем цикле.

Одна из проблем, связанных с вложенными циклами — организация досрочного выхода из них. Во многих языках программирования есть оператор досрочного завершения цикла (break в Си, exit в Турбо Паскале, last в Perl и т. п.), но он, как правило, обеспечивает выход только из цикла того уровня, откуда вызван. Вызов его из вложенного цикла приведёт к завершению только этого внутреннего цикла, внешний же цикл продолжит выполняться. Проблема может показаться надуманной, но она действительно иногда возникает при программировании сложной обработки данных, когда алгоритм требует немедленного прерывания в определённых условиях, наличие которых можно проверить только в глубоко вложенном цикле.

Решений проблемы выхода из вложенных циклов несколько.

  • Простейший — использовать оператор безусловного перехода goto для выхода в точку программы, непосредственно следующую за вложенным циклом. Этот вариант критикуется сторонниками структурного программирования, как и все конструкции, требующие использования goto. Некоторые языки программирования, например, Модула-2, просто, не имеют оператора безусловного перехода, и в них подобная конструкция невозможна.
  • Альтернатива — использовать штатные средства завершения циклов, в случае необходимости устанавливая специальные флаги, требующие немедленного завершения обработки. Недостаток — усложнение кода, снижение производительности.
  • Размещение вложенного цикла в процедуре. Идея состоит в том, чтобы всё действие, которое может потребоваться прервать досрочно, оформить в виде отдельной процедуры, и для досрочного завершения использовать оператор выхода из процедуры (если такой есть в языке программирования). В языке Си, например, можно построить функцию с вложенным циклом, а выход из неё организовать с помощью оператора return. Недостаток — выделение фрагмента кода в процедуру не всегда логически обосновано, и не все языки имеют штатные средства досрочного завершения процедур.
  • Воспользоваться механизмом генерации и обработки исключений (исключительных ситуаций), который имеется сейчас в большинстве языках высокого уровня. В этом случае в нештатной ситуации код во вложенном цикле возбуждает исключение, а блок обработки исключений, в который помещён весь вложенный цикл, перехватывает и обрабатывает его. Недостаток — реализация механизма обработки исключений в большинстве случаев такова, что скорость работы программы уменьшается. Правда, в современных условиях это не особенно важно: практически потеря производительности столь мала, что имеет значение лишь для очень немногих приложений.
  • Наконец, существуют специальные языковые средства для выхода из вложенных циклов. Так, в языке Ада программист может пометить цикл (верхний уровень вложенного цикла) меткой, и в команде досрочного завершения цикла указать эту метку. Выход произойдёт не из текущего цикла, а из всех вложенных циклов до помеченного, включительно[2]. Язык PHP предоставляет возможность указать число прерываемых циклов после команды break — так break 2 прервёт сам цикл и вышестоящий над ним, а break 1 эквивалентно простой записи команды break[3].

Циклы с несколькими охраняемыми ветвями

Цикл Дейкстры

В теории программирования известна ещё одна, принципиально отличающаяся от «классических», форма циклической конструкции, получившая название «цикл Дейкстры», по имени Эдсгера Дейкстры, впервые её описавшего. В классическом дейкстровском описании такой цикл выглядит следующим образом:

 do
   P1 → S1,
     …
   Pn → Sn
 od

Здесь do — маркер начала конструкции цикла, od — маркер завершения конструкции цикла, Pi — i-тое охраняющее условие (логическое выражение, которое может иметь значение «истинно» или «ложно»), Si — i-я охраняемая команда. Цикл состоит из одной или нескольких ветвей (охраняемых выражений), каждая из которых представляет собой пару из охраняющего условия (или, коротко, «охраны») и охраняемой команды (понятно, что в реальности команда может быть сложной).

При выполнении цикла Дейкстры в каждой итерации происходит вычисление охраняемых условий. Если хотя бы одно из них истинно, выполняется соответствующая охраняемая команда, после чего начинается новая итерация (если истинны несколько охраняемых условий, выполняется только одна охраняемая команда). Если все охраняемые условия ложны, цикл завершается. Нетрудно заметить, что цикл Дейкстры с одним охраняющим условием и одной охраняемой командой представляет собой, по сути, обычный цикл с предусловием (цикл «пока»).

Хотя цикл Дейкстры был изобретён ещё в 1970-х годах, специальных конструкций для его создания в языках программирования не содержится. Единственным исключением стал недавно созданный Оберон-07 — первый реальный язык программирования, явно поддерживающий цикл с несколькими охраняемыми ветвями. Впрочем, цикл Дейкстры может быть без больших затруднений смоделирован с помощью традиционных конструкций структурных языков программирования. Вот пример его реализации одним из возможных способов на языке Ада:

loop
  if P1 then 
    S1;
    ...
  elsif Pn then 
    Sn;
  else
    exit;
  end if;
end loop;

Здесь P1-Pn — охраняющие условия, а S1-Sn — соответствующие охраняемые команды.

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

Цикл «паук»

Легко видеть, что цикл Дейкстры не содержит явного условия продолжения или выхода, что не всеми теоретиками программирования рассматривается как благо. Поэтому была предложена усложнённая конструкция цикла Дейкстры, получившая название «цикл-'паук'». В той же нотации она выглядит следующим образом:

 do
   P1→S1,
     …
   Pn→Sn
 out
   Q1→T1,
     …
   Qn→Tn
 else
   E
 od

Здесь после маркера out добавлены ветви завершения, состоящие из условий выхода Qi и команд завершения Ti. Кроме того, добавлена ветвь альтернативного завершения else с командой E.

Цикл-'паук' выполняется так:

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

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

Хотя явной поддержки на уровне синтаксиса для этого цикла не существует ни в одном языке программирования, цикл-'паук', как и цикл Дейкстры, может быть смоделирован с помощью традиционных структурных конструкций.

Интересные факты

  • Никлаус Вирт одно время называл цикл со счётчиком «маргинальным», утверждая, что такая конструкция является излишней и должна быть исключена из синтаксиса языков программирования как несистемная. В соответствии с этим представлением в языке программирования Оберон цикла со счётчиком не было. Однако в языке Оберон-2, созданном Виртом и Мёссенбёком в развитие Оберона, цикл со счётчиком FOR появился снова в интересах практического удобства использования[4].

См. также

Методы оптимизации циклов

Примечания

Ссылки

dic.academic.ru

ЦИКЛ - это... Что такое ЦИКЛ?

  • цикл — цикл, а …   Русский орфографический словарь

  • цикл — цикл/ …   Морфемно-орфографический словарь

  • Цикл — совокупность процессов в системе периодически повторяющихся движений, при которых объект, подвергающийся изменению в определенной последовательности, вновь приходит в исходное положение. Источник: ГОСТ 2846 …   Словарь-справочник терминов нормативно-технической документации

  • цикл — сущ., м., употр. сравн. часто Морфология: (нет) чего? цикла, чему? циклу, (вижу) что? цикл, чем? циклом, о чём? о цикле; мн. что? циклы, (нет) чего? циклов, чему? циклам, (вижу) что? циклы, чем? циклами, о чём? о циклах 1. Циклом называются… …   Толковый словарь Дмитриева

  • ЦИКЛ — (греч. «круг») группа известных наук, сочинений и пр.; в хронологии период, по окончании которого одни и те же явления повторяются в том же порядке. Словарь иностранных слов, вошедших в состав русского языка. Павленков Ф., 1907. ЦИКЛ (греч.… …   Словарь иностранных слов русского языка

  • цикл — а, м. cycle m. &LT; лат. cyclus &LT;гр. kyklos круг. 1. Закономерный, регулярный круг каких н. явлений, действий, процессов. Производственный цикл. БАС 1. Целый цикл жизни отжила наша Русь, и, возрожденная, преобразованная Петром Великим, начала… …   Исторический словарь галлицизмов русского языка

  • Цикл — (cycle) Любая ситуация, при которой процедура голосования для выбора из большого числа вариантов отдает предпочтение А над В, В над С... i над j, j над А. Самый известный пример – цикл простого мажоритарного правила, открытого Кондорсе… …   Политология. Словарь.

  • цикл — а; м. 1. Совокупность каких л. явлений, процессов, работ, составляющих законченный круг действия, развития чего л. Производственный ц. Годовой ц. вращения планеты. Менструальный ц. Короткий биологический ц. Одногодичный ц. развития листьев. Ц.… …   Энциклопедический словарь

  • ЦИКЛ — (от греч. kyklos круг) ..1) совокупность явлений, процессов, составляющая кругооборот в течение известного промежутка времени (напр., годовой цикл)2)] Группа наук, дисциплин (напр., исторический цикл)3) Законченный Ряд каких либо произведений,… …   Большой Энциклопедический словарь

  • ЦИКЛ — (греч. kyklos круг) совокупность процессов, работ, операций, образующих в совокупности законченную круговую последовательность. Например, жизненный цикл, производственный цикл, воспроизводственный цикл. См. также ЭКОНОМИЧЕСКИЙ ЦИКЛ. Райзберг Б.А …   Экономический словарь

  • dic.academic.ru

    Цикл - это... Что такое Цикл?

    ЦИКЛ (от греч. κύκλος — круг) означает, в применении к литературе, ряд произведений, связанных общим сюжетом и составом действующих лиц. Цикл, в той или иной своей форме, составляет принадлежность как литературы античной, так и литературы средневековой. Встречается он и в новой литературе, и в русской народной словесности.

    Понятие цикла имеет не только значение руководящей идеи при исследованиях о происхождении таких поэм, как Иллиада, Одиссея — у греков, Песнь о Роланде — на Западе и пр., но и значение обще-теоретическое — при изучении тех изобразительных особенностей, которые определяются наличностью цикловой связи.

    Первое значение этого понятия, относясь к истории литературных жанров, лишь косвенно причастно, как и всякий исторический материал, к теории художественного слова. Во втором же своем значении — цикл одно из центральных теоретико-литературных понятий.

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

    Примером первого рода циклов может служить греческая циклическая поэзия, состоящая из множества поэм, принадлежащих различным авторам, где описываются подвиги греческих богов и героев. Так, хрестоматия Прокла передает нам содержание некоторых из них. В «Теогонии» и «Титаномахии» рассказывается о женитьбе Урана на Гее (Неба на Земле), о рождении гигантов и циклопов, о битве между ними и богами, заканчивающейся победою Зевса. Поэмы связаны между собою своими героями и в сюжете своем дополняют друг друга. Такая же сюжетная и персональная связь между содержанием поэм и у германских и романских народов. Таковы поэмы Каролингского цикла, романы Круглого Стола, сказания о Нибелунгах, такова и обширная сатирическая эпопея средневековья «Роман о Лисе». Русская народная эпика дает в своих былинах примеры подобной же циклизации — вокруг любимых богатырей — Ильи Муромца, Добрыни Никитича, вокруг центральной фигуры былевого творчества Владимира Красное Солнышко.

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

    Последующее нарастание циклового материала вокруг любимых героев объясняется стремлением приурочить новое повествование к известному уже лицу, чтобы вызвать этим больше внимания и больше сочувствия. Благодаря наличности обширных циклов, любимые герои их обретают как бы полу-реальное существование, становятся старыми знакомцами, даже если данный отдельный эпизод воспринимается впервые. Художественный эффект подобных обращений к прошлому литературному опыту слушателя или читателя находит себе аналогию в лирической поэзии, где поэт нередко называет знакомых литературных героев, вызывая этим в «памяти сердца» волну эстетических эмоций, связанных с названным именем. (См. об этом в статье под словом «имя»).

    Новая литература дает образцы цикла как в области художественной прозы, так и в области поэзии, в области научной и литературно-критической. Впрочем, лишь в применении к художественной прозе понятие это обладает некоторой отчетливостью, — в применении же к остальным областям оно нередко без разбора употребляется вместо слов «сборник статей», «книга стихов» и пр.

    Ярко выраженное цикловое построение дает Э. Золя в своей серии «Ругон-Макары», в наши дни — Ромэн Роллан в «Жан Кристофе». Циклизация материала и здесь, и там способствовала более расчлененному выполнению основного задания автора: для Золя облегчила разрешение центрального вопроса о наследственности — в применении к отдельным лицам; связанным, между собою узами родства, для Ромэн Роллана помогла осветить отдельные этапы в истории творческой личности Жан Кристофа. Помимо этого, цикловое построение способствовало опять-таки — и здесь и там — более стройной компановке фабульного материала, слишком обширного для одного сюжетного центра.

    Валентина Дынник. Литературная энциклопедия: Словарь литературных терминов: В 2-х т. / Под редакцией Н. Бродского, А. Лаврецкого, Э. Лунина, В. Львова-Рогачевского, М. Розанова, В. Чешихина-Ветринского. — М.; Л.: Изд-во Л. Д. Френкель, 1925

    dic.academic.ru

    цикл - это... Что такое цикл?

    Морфология: (нет) чего? ци́кла, чему? ци́клу, (вижу) что? ци́кл, чем? ци́клом, о чём? о ци́кле; мн. что? ци́клы, (нет) чего? ци́клов, чему? ци́клам, (вижу) что? ци́клы, чем? ци́клами, о чём? о ци́клах

    1. Циклом называются несколько явлений, процессов, работ, которые составляют законченный круг какого-то общего действия, развития чего-либо.

    Полный производственный цикл. | Цикл переменного тока. | 11-летний цикл солнечной активности. | Годовой цикл вращения планеты.

    2. Циклом называют период времени между какими-то важными событиями, изменениями в жизни природы, общества, человека.

    Социально-экономический цикл. | Природный цикл. | Демографический цикл.

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

    4. Циклом двигателя называют период выработки этим двигателем энергии и возвращение его в первоначальное состояние.

    Цикл двигателя внутреннего сгорания. | Рабочий цикл станка.

    5. В компьютерном программировании циклом называется группа команд, которые выполняются многократно в зависимости от заданных условий какой-либо операции.

    Оператор цикла. | Нормальный, удлинённый, бесконечный цикл.

    6. В строительстве нулевым циклом называется период подготовительных работ.

    7. Циклом лекций, передач и т. п. называется несколько лекций, передач и т. п., которые тематически связаны, имеют общую идею.

    Цикл лекций по изобразительному искусству. | Научно-исторический цикл телепередач.

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

    Стихотворный цикл. | Фортепьянный цикл пьес.

    цикли́чный

    цикли́ческий

    цикли́чность

    dic.academic.ru

    первая, вторая, третья, что это такое

    Время чтения: 6 мин.

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

    Организм женщины - загадка природы, его можно изучать без конца.

    Большое влияние на самочувствие и эмоциональный фон оказывает менструальный цикл. Долг каждой женщины – знать о нем и уметь чувствовать свой организм.

    1. Что такое менструальный цикл?

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

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

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

    Когда девочка появляется на свет, в ее яичниках насчитывается около 2 миллионов яйцеклеток, но к периоду полового созревания их остается не больше 400 тысяч. Во время 1 цикла, как правило, расходуется 1 яйцеклетка.

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

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

    В среднем его длительность составляет 28 дней. Но цикл, который длится от 21 до 35 дней, также считается нормальным.

    Если цикл не укладывается в эти временные отрезки, это не является нормой. В этом случае стоит обратиться к гинекологу и пройти комплексное обследование под его руководством.

    Изображение 1

    Рисунок 1 - Схема фаз менструального цикла

    2. Фазы цикла

    Менструальный цикл состоит из нескольких фаз. Фазы по изменениям в яичниках и эндометрии отличаются (см. схему на рисунке 1 и таблицу). Каждая из них имеет свои особенности и характеристики.

    Фаза овариального цикла и ее длительностьФаза по эндометриюОсобенностиПризнаки
    Фолликулярная (в среднем 14 дней, колебания от 7 до 22 дней)Менструальная + пролиферативнаяФСГ стимулирует образование фолликулов.

    Нарастание концентрации эстрогенов с 3-5 дня, рост обновленного эндометрия.

    Начинается с одновременно менструацией.

    Появляются кровянистые выделения.

    Женщина в первые дни чувствует себя плохо, ее беспокоят боли внизу живота, тянет поясницу, настроение снижено.

    После окончания месячных выделения умеренные или скудные, состояние кожи постепенно нормализуется.

    Овуляция (1-2 дня)---Резкий выброс ЛГ стимулирует выход яйцеклетки из фолликула.

    Движение яйцеклетки по маточной трубе.

    Увеличение сексуального влечения, умеренные боли в области поясницы, внизу живота.

    Количество светлых выделений увеличивается, они становятся слизистыми, тягучими или жидкими.

    Кожа под влиянием эстрогенов чистая, ровная, сияющая.

    Повышение базальной температуры.

    Лютеиновая (14 дней +/- 2)СекреторнаяФолликул преобразовывается в желтое тело, начинается выработка прогестерона.

    Пик его концентрации приходится на 6-8 день после образования желтого тела.

    В середине фазы на фоне гормональных сдвигов у некоторых возникает предменструальный синдром.

    К его симптомам относятся набухание молочных желез, снижение настроения, плаксивость или агрессия, повышение аппетита, тянущие боли внизу живота, повышение веса, отеки, головные боли, реже запоры, метеоризм.

    Таблица 1 - Фазы менструального цикла

    2.1. Фолликулярная

    Самую первую фазу менструального цикла называют фолликулярной. Она начинается в 1 день месячных, а ее конец приходится на тот день, когда происходит овуляция.

    Во время месячных происходит отторжение поверхностного слоя слизистой оболочки матки и начинается кровотечение.

    В 1-3 день цикла матка выглядит как раневая поверхность, вероятность попадания инфекции в эти дни велика. К 5 дню толщина эндометрия начинает нарастать.

    Во время первой фазы в яичниках под влиянием ФСГ (фолликулостимулирующего гормона) созревают фолликулы.

    Изначально их может быть несколько, но лишь один закончит процесс созревания, став доминирующим (основным).

    В этот период происходит активный рост (пролиферация) эндометрия в матке под влиянием высокой концентрации эстрогенов (преимущественно эстрадиола).

    Таким образом, фолликулярная фаза по времени соотносится с менструацией и фазой пролиферации эндометрия, то есть охватывает 1-14 дни.

    2.2. Овуляция

    Она начинается после резкого выброса ЛГ (лютеинизирующего гормона). После того как доминирующий фолликул лопается, из него выходит яйцеклетка и начинает свое движение по маточной трубе.

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

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

    1. 1Женщина начинает испытывать сильное сексуальное желание.
    2. 2Базальная температура поднимается.
    3. 3Количество выделений увеличивается, они становятся слизистыми, тягучими, но остаются светлыми и сопровождаются другими симптомами.
    4. 4В пояснице могут возникать умеренные, тянущие боли.

    2.3. Лютеиновая

    Вторая фаза характеризуется образованием и ростом желтого тела на месте разорвавшегося фолликула. В среднем она длится 12-16 дней. Желтое тело готовит организм к беременности и вырабатывает прогестерон.

    Максимальная концентрация прогестерона наблюдается через 6-8 дней после образования желтого тела (примерно 22 день цикла).

    Эндометрий в это период еще больше утолщается, только за счет образования секрета маточными железами и увеличения размеров клеток (третья фаза секреции). Толщина его в конце лютеиновой фазы может достигать 12-14 мм.

    Если зачатия не происходит, то уровень гормонов (эстрогенов, прогестерона, ФСГ, ЛГ) постепенно начинает снижаться. Их минимум запускает начало менструации, начинается новый цикл.

    На этот процесс влияют стрессы, вредные привычки и перенесенные заболевания.

    3. Причины нарушений менструального цикла

    Из-за чего нарушается цикл?Состояния и болезни
    Ановуляция (нет нормальной овуляции)СПКЯ (синдром поликистозных яичников), овариальная недостаточность
    Гипоталамический синдром, опухоли и другие заболевания гипофиза
    Избыточные тренировки и физические нагрузки
    Расстройства пищевого поведения, нервная анорексия, булимия
    Гиперпролактинемия
    Болезнь Кушинга
    Патологии щитовидной железы
    Снижение качества эндометрияРак, гиперплазия эндометрия, эндометрит, полипы, эндометриоз (аденомиоз)
    Влияние на яичникиКисты, опухоли, аднексит, рак
    Изменение уровней гормонов-регуляторовНеправильный прием и подбор оральных контрацептивов, внутриматочных систем, ранняя менопауза, прием тамоксифена, препаратов прогестерона
    Влияние на несколько звеньевВоспалительные заболевания шейки матки и влагалища, в том числе ЗППП (хламидиоз, генитальный герпес, трихомониаз, гонорея)
    Прием лекарственных средств (например, антикоагулянтов)
    Общие соматические заболевания: почек, печени, надпочечников, сахарный диабет, воспалительные заболевания кишечника, гемофилия и другие болезни свертывающей системы крови, онкология и др.

    4. На что нужно обратить внимание?

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

    Что не является нормой, на какие тревожные знаки следует обратить внимание?

    1. 1Если месячные идут чаще, чем 1 раз в 21 день, или реже, чем 1 раз в 35 дней, стоит обратиться к врачу.
    2. 2Обильные кровотечения, когда 1 прокладки или 1 тампона не хватает на 2 часа.
    3. 3Возникают межменструальные кровянистые выделения и кровомазание.
    4. 4Менструация длится более 7 дней.
    5. 5Во время месячных или в период овуляции возникают интенсивные боли внизу живота, которые мешают полноценно работать, учиться и заниматься повседневными делами.
    6. 6Симптомы предменструального синдрома резко выражены, снижают качество жизни.

    5. Зачем нужен дневник месячных?

    Гинекологи рекомендуют всем девушкам и женщинам вести дневник менструального цикла.

    Сейчас нет никакой необходимости заводить для этого специальную тетрадь. Можно установить на свой телефон приложение и регулярно вводить данные. Такой дневник нужен, чтобы знать среднее время одного цикла.

    Иллюстрация 2

    Как выглядит менструальный календарь?

    Если его длительность резко меняется, дневник поможет узнать характер нарушений.

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

    Электронные приложения предлагают ежемесячно вводить дату начала и конца месячных. На основе этих данных они автоматически рассчитают продолжительность цикла, время овуляции, неблагоприятные дни для планирования ребенка и время начала следующей менструации.

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

    Все эти данные при необходимости облегчат работу врачу и помогут выявить причины нарушений.

    sterilno.net

    Цикл - это... Что такое Цикл?

  • цикл — цикл, а …   Русский орфографический словарь

  • цикл — цикл/ …   Морфемно-орфографический словарь

  • Цикл — совокупность процессов в системе периодически повторяющихся движений, при которых объект, подвергающийся изменению в определенной последовательности, вновь приходит в исходное положение. Источник: ГОСТ 2846 …   Словарь-справочник терминов нормативно-технической документации

  • ЦИКЛ — ЦИКЛ, цикла, муж. (греч. kyklos, букв. колесо). 1. Совокупность каких нибудь явлений, процессов, работ, совершающих законченный круг развития в течение какого нибудь промежутка времени. Производственный цикл (совокупность процессов от самого… …   Толковый словарь Ушакова

  • цикл — сущ., м., употр. сравн. часто Морфология: (нет) чего? цикла, чему? циклу, (вижу) что? цикл, чем? циклом, о чём? о цикле; мн. что? циклы, (нет) чего? циклов, чему? циклам, (вижу) что? циклы, чем? циклами, о чём? о циклах 1. Циклом называются… …   Толковый словарь Дмитриева

  • ЦИКЛ — (греч. «круг») группа известных наук, сочинений и пр.; в хронологии период, по окончании которого одни и те же явления повторяются в том же порядке. Словарь иностранных слов, вошедших в состав русского языка. Павленков Ф., 1907. ЦИКЛ (греч.… …   Словарь иностранных слов русского языка

  • цикл — а, м. cycle m. &LT; лат. cyclus &LT;гр. kyklos круг. 1. Закономерный, регулярный круг каких н. явлений, действий, процессов. Производственный цикл. БАС 1. Целый цикл жизни отжила наша Русь, и, возрожденная, преобразованная Петром Великим, начала… …   Исторический словарь галлицизмов русского языка

  • Цикл — (cycle) Любая ситуация, при которой процедура голосования для выбора из большого числа вариантов отдает предпочтение А над В, В над С... i над j, j над А. Самый известный пример – цикл простого мажоритарного правила, открытого Кондорсе… …   Политология. Словарь.

  • цикл — а; м. 1. Совокупность каких л. явлений, процессов, работ, составляющих законченный круг действия, развития чего л. Производственный ц. Годовой ц. вращения планеты. Менструальный ц. Короткий биологический ц. Одногодичный ц. развития листьев. Ц.… …   Энциклопедический словарь

  • ЦИКЛ — (от греч. kyklos круг) ..1) совокупность явлений, процессов, составляющая кругооборот в течение известного промежутка времени (напр., годовой цикл)2)] Группа наук, дисциплин (напр., исторический цикл)3) Законченный Ряд каких либо произведений,… …   Большой Энциклопедический словарь

  • ЦИКЛ — (греч. kyklos круг) совокупность процессов, работ, операций, образующих в совокупности законченную круговую последовательность. Например, жизненный цикл, производственный цикл, воспроизводственный цикл. См. также ЭКОНОМИЧЕСКИЙ ЦИКЛ. Райзберг Б.А …   Экономический словарь

  • dic.academic.ru

    Что такое цикл? Что такое жизненный цикл? :: SYL.ru

    Что такое цикл? Это понятие имеет много значений. Трактовка зависит от специфики рассматриваемого процесса, а также от науки или дисциплины, где этот термин рассматривается.

    Понятие

    Существует несколько трактовок, которые описывают что такое цикл:

    • Определенная совокупность процессов, работ и разнообразных явлений, которые связаны между собою.
    • Законченный ряд определенных понятий, проявлений и др.
    • Группа наук или дисциплин, которые объединены одной общей характеристикой.

    В общем, цикл подразумевает кругооборот, повторение чего-либо в рамках конкретного промежутка времени.

    что такое цикл

    Основные составляющие

    Понятие цикла включает определенные компоненты, которые позволяют более точно охарактеризовать данный процесс. Сюда относятся такие термины, как фаза, время, день и др.

    Что такое фаза цикла? Под этим понимают конкретный период, степень или этап развития чего-либо. Любой цикл состоит из нескольких фаз, которые имеют определенную последовательность и постепенно переходят одна в другую.

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

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

    что такое день цикла

    Понятие цикла в разных науках

    Цикл в разных науках и дисциплинах имеет следующую трактовку:

    • Биология. Регулярная и закономерная смена поколений, которая характерна для конкретного вида живых организмов.
    • Астрономия. Периодичность изменений, которым звезда подвергается в своей жизни.
    • Инженерия. Совокупность стадий процесса, который характеризует различные состояния системы сначала и до конца ее эксплуатации.
    • Программирование. Отрезок времени с начала принятия решения о создании конкретного программного продукта и до снятия программы с эксплуатации.
    • Экономика. Совокупность этапов развития фирмы за весь период ее существования.

    Также цикл присутствует в производстве, строительстве и многих других науках и дисциплинах.

    что такое жизненный цикл

    Жизненный цикл в биологии

    Чаще всего данный термин рассматривается в биологии как по отношению к конкретному организму, так и при характеристике клеток. Что такое жизненный цикл? Данный процесс описывает смену поколений разных видов живых организмов. В зависимости от особенностей и характера изменений в организме, различают следующие типы жизненного цикла.

    • Гаплоидный. В этом случае на протяжении всего цикла организм имеет одинаковый набор хромосом. Это характерно для бактерий и протистов, которые не имеют полового процесса.
    • Зиготический. Образование зиготы и протекание мейоза. Эта процедура характерна для зеленых и других водорослей, а также для большинства грибков и протистов.
    • Наличие диплоидности почти на всех стадиях жизненного цикла. Это характерно для многоклеточных животных.
    • На диплоидных и гаплоидных этапах осуществляются митотические деления. Это характерно для всех высших растений.

    Жизненный цикл ИТ-систем

    Что такое цикл в системе информационных технологий? Любые данные существуют на протяжении некоторого времени, а передача информации может осуществляться как кратковременно (например, в памяти калькулятора), так и очень долго (при хранении важных данных государственного уровня). Жизненный цикл информационной системы состоит из следующих компонентов:

    • Постановка конкретной задачи.
    • Проектирование и предварительная разработка услуг.
    • Модернизация услуги в случае, если она имеет плохой уровень качества, или же ее полная ликвидация.

    Эти этапы характерны практически для любой информационной системы.

    что такое фаза цикла

    Жизненный цикл программного обеспечения

    Что такое цикл в программировании? Данный процесс состоит из следующих этапов:

    • Анализ существующих требований к программному обеспечению.
    • Проектирование программы.
    • Тестирование программного обеспечения и его отладка.
    • Эксплуатация софта с детальным пошаговым сопровождением.

    Жизненный цикл большинства современных программ для компьютера составляет 2-3 года, хотя существуют исключения, которые функционируют более десяти лет.

    что такое период цикла

    Жизненный цикл организации

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

    Жизненный цикл организации предвидит следующие этапы:

    • Предпринимательство. В этом случае организация находится в процессе обновления. Ее цели еще неконкретные и нечеткие, а творческий процесс имеет свободный характер. Для продвижения к следующему этапу необходимо наличие стабильных ресурсов.
    • Коллективность. Для того чтобы разобраться в процессе, нужно узнать, что такое вторая фаза цикла. Этот этап предвидит формирование миссии организации, однако сфера коммуникаций, и сама структура процесса все еще неформальны.
    • Формализация и управление. На этом этапе структура организации становится более стабильной, появляются определенные правила, которые характеризуют процедуру. Роль высшего руководства становится важной, а процесс принятия решение уже носит взвешенный и конструктивный характер.
    • Разработка структуры. Организация начинает увеличивать выпуск своей продукции и значительно расширяет спектр услуг. Структура организации становится более четкой и комплексной. Решения в организации принимаются децентрализовано.
    • Упадок. Конкуренция приводит к тому, что рынок организации сокращается, уменьшается спрос на ее продукцию и руководитель ищет другие пути и новые возможности. Увеличивается количество работников. Руководство организации меняется, а принятие решений начинает носить централизованный характер.

    Знание того, на каком именно этапе цикла находится организация, позволяет руководству координировать свои действия и принять оптимальное решение в каждом конкретном случае.

     что такое время цикла

    Жизненный цикл продукта

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

    • Осуществление маркетинговых исследований, нацеленных на выявление потребностей общества.
    • Проектирование будущей продукции.
    • Планирование процесса изготовления и его детальная разработка.
    • Закупка необходимых ресурсов и оборудования.
    • Производство продукции и ее обслуживание.
    • Проверка работоспособности процесса.
    • Упаковка продукции и варианты хранения.
    • Разъяснение вопросов продажи и распределения.
    • Наладка, настройка и монтаж.
    • Техническая поддержка продукции и ее обслуживание.
    • Эксплуатация продуктов согласно их назначения.
    • Деятельность послепродажного характера.
    • Переработка продукта или его утилизация.

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

    что такое вторая фаза цикла

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

    www.syl.ru

    Добавить комментарий

    Ваш адрес email не будет опубликован. Обязательные поля помечены *