Jump to content

Строгая функция

В информатике и компьютерном программировании функция f называется строгой , если при ее применении к незавершающемуся выражению она также не может завершиться. [1] Строгая функция в денотационной семантике языков программирования — это функция f , где . Сущность , называемый нижней , обозначает выражение, которое не возвращает нормальное значение либо потому, что оно повторяется бесконечно, либо потому, что оно прерывается из-за ошибки, такой как деление на ноль. Функция, которая не является строгой, называется нестрогой . Строгий язык программирования — это язык, в котором пользовательские функции всегда строгие.

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

В качестве примера, if-then-else выражение многих языков программирования, называемое ?: в языках, вдохновленных C, можно рассматривать как функцию трех параметров. Эта функция является строгой в отношении своего первого параметра, поскольку функция должна знать, имеет ли ее первый аргумент значение true или false, прежде чем она сможет вернуться; но он нестрогий по второму параметру, потому что (например) if(false,,1) = 1, а также нестрого по третьему параметру, потому что (например) if(true,2,) = 2. Однако он является одновременно строгим по второму и третьему параметрам, поскольку if(true,,) = и if(false,,) = .

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

См. также

[ редактировать ]
  1. ^ «Нежное введение в Haskell: функции» . www.haskell.org . Проверено 23 июня 2016 г.
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: cb37aaf5d80ac5d1eae05d616a256925__1603546980
URL1:https://arc.ask3.ru/arc/aa/cb/25/cb37aaf5d80ac5d1eae05d616a256925.html
Заголовок, (Title) документа по адресу, URL1:
Strict function - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)