Заявление (информатика) - Statement (computer science)

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

Многие императивные языки (например, C ) проводить различие между утверждениями и определениями, причем утверждение содержит только исполняемый файл код и определение создание экземпляра ан идентификатор, в то время как выражение оценивает только значение. Также можно различать простые и составные утверждения; последние могут содержать операторы как компоненты.

Виды заявлений

Ниже приведены некоторые из основных типов псевдокодированных операторов. Эти псевдокодированные операторы имеют соответствующий синтаксис в любом типичном императивном языке, таком как Паскаль, C, Фортран и т. Д .:

Простые утверждения

  • утверждение
    • в C: утверждать(ptr! = NULL);
  • назначение
    • в Паскале: А := А + 5
    • в C и Фортране: А = А + 5
  • идти к
    • в C и Фортране: идти к метка;
  • возвращаться
    • в C и Фортране: возвращаться ценить;
    • в Паскале: результат: = ценить;
  • вызов
    • в C и Паскале: ОЧИСТИ ЭКРАН()
    • в Фортране: вызов ОЧИСТИ ЭКРАН()

Составные заявления

  • блокировать:
    • в Паскале: начинать ... конец
    • в C: { ... }
  • петля: сделать {вычисление (& я); } while (i <10);
  • for-loop: для A: = от 1 до 10 сделать WRITELN (A) end
  • если-заявление: если A> 3, то WRITELN (A) else WRITELN («НЕТ»); конец
  • оператор-переключатель: переключатель (c) {case 'a': alert (); перемена; case 'q': выйти (); перемена; }
  • цикл while: в то время как НЕ EOF действительно начинается READLN end
  • с заявлением: с open (имя файла) как f: используйте (f)

Синтаксис

Внешний вид утверждений определяет внешний вид программ. Языки программирования характеризуются типом используемых в них операторов (например, язык фигурных скобок семья). Многие утверждения вводятся идентификаторы подобно если, пока или же повторение. Часто заявление ключевые слова зарезервированы, поэтому их нельзя использовать в качестве имен переменные или же функции. Императивные языки обычно используют специальный синтаксис для каждого оператора, который сильно отличается от вызовов функций. Распространенные методы описания синтаксиса операторов: Форма Бэкуса – Наура и синтаксические диаграммы.

Семантика

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

Выражения

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

Например:

  • Заявление
    • print ('Привет, мир.')
  • Выражение:
    • X = ваши данные
    • печать (X)

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

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


Оператор - это инструкция, которую может выполнить интерпретатор Python. Пока мы видели только оператор присваивания. Некоторые другие типы операторов, которые мы вскоре увидим, - это операторы while, операторы for, операторы if и операторы импорта. (Есть и другие виды!)

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

Расширяемость

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

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

Рекомендации

  1. ^ "утверждение". Вебопедия. Получено 2015-03-03.

внешняя ссылка