Jump to content

Синтаксическая диаграмма

Синтаксические диаграммы (или железнодорожные диаграммы ) — это способ представления контекстно-свободной грамматики . Они представляют собой графическую альтернативу форме Бэкуса-Наура , EBNF , расширенной форме Бэкуса-Наура и другим текстовым грамматикам как метаязыкам . Ранние книги, в которых используются синтаксические диаграммы, включают «Руководство пользователя Pascal», написанное Никлаусом Виртом. [1] (диаграммы начинаются на стр. 47) и руководство Burroughs CANDE . [2] В области компиляции обычно предпочтительны текстовые представления, такие как BNF или его варианты. BNF основан на тексте и используется авторами компиляторов и генераторами синтаксических анализаторов. Схемы железных дорог наглядны и могут быть более понятны непрофессионалам, иногда их включают в графический дизайн. Канонический источник, определяющий JSON формат обмена данными , представляет собой еще один пример популярного современного использования этих диаграмм.

Принцип синтаксических диаграмм

[ редактировать ]

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

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

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

БНФ:

<expression> ::= <term> | <term> "+" <expression>
<term>       ::= <factor> | <factor> "*" <term>
<factor>     ::= <constant> | <variable> | "(" <expression> ")"
<variable>   ::= "x" | "y" | "z" 
<constant>   ::= <digit> | <digit> <constant>
<digit>      ::= "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9"

ЕБНФ:

expression = term , [ "+" , expression ];
term       = factor , [ "*" , term ];
factor     = constant | variable | "(" , expression , ")";
variable   = "x" | "y" | "z"; 
constant   = digit , { digit };
digit      = "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9";

АБНФ:

expression = term ["+" expression]
term       = factor ["*" term]
factor     = constant / variable / "(" expression ")"
variable   = "x" / "y" / "z"
constant   = 1*digit
DIGIT      = "0" / "1" / "2" / "3" / "4" / "5" / "6" / "7" / "8" / "9"

ABNF также поддерживает диапазоны, например DIGIT = %x30-39, но здесь он не используется для согласованности с другими примерами.

Красный (язык программирования) Диалект разбора:

Red [Title: "Parse Dialect"]
expression: [term opt ["+" expression]]
term:       [factor opt ["*" term]]
factor:     [constant | variable | "(" expression ")"]
variable:   ["x" | "y" | "z"]
constant:   [some digit]
digit:      ["0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9"]

Этот формат также поддерживает диапазоны, например digit: charset [#"0" - #"9"], но здесь он не используется для согласованности с другими примерами.

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

Синтаксическая диаграмма «Железная дорога»

См. также

[ редактировать ]

Примечание: первая ссылка иногда блокируется сервером за пределами своего домена, но она доступна на archive.org . Файл также был отражен на сайте Standardpascal.org .

[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 72c03028ccc7e1535228e5464b90d6dd__1704216360
URL1:https://arc.ask3.ru/arc/aa/72/dd/72c03028ccc7e1535228e5464b90d6dd.html
Заголовок, (Title) документа по адресу, URL1:
Syntax diagram - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)