<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Erweiterte_Backus-Naur-Form</id>
	<title>Erweiterte Backus-Naur-Form - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Erweiterte_Backus-Naur-Form"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Erweiterte_Backus-Naur-Form&amp;action=history"/>
	<updated>2026-06-02T14:01:05Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Erweiterte_Backus-Naur-Form&amp;diff=21117&amp;oldid=prev</id>
		<title>imported&gt;SchlurcherBot: Bot: http → https</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Erweiterte_Backus-Naur-Form&amp;diff=21117&amp;oldid=prev"/>
		<updated>2025-07-10T15:44:21Z</updated>

		<summary type="html">&lt;p&gt;Bot: http → https&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Die &amp;#039;&amp;#039;&amp;#039;Erweiterte Backus-Naur-Form&amp;#039;&amp;#039;&amp;#039;, kurz &amp;#039;&amp;#039;&amp;#039;EBNF&amp;#039;&amp;#039;&amp;#039;, ist eine Erweiterung der [[Backus-Naur-Form]] (BNF), die ursprünglich von [[Niklaus Wirth]] zur Darstellung der Syntax der Programmiersprache [[Pascal (Programmiersprache)|Pascal]] eingeführt wurde. Sie ist eine formale Metasyntax ([[Metasprache]]), die benutzt wird, um [[kontextfreie Grammatik]]en darzustellen.&lt;br /&gt;
&lt;br /&gt;
Die EBNF ist von der [[International Organization for Standardization|ISO]] als &amp;#039;&amp;#039;ISO/IEC 14977:1996(E)&amp;#039;&amp;#039; standardisiert. Die Beispiele in diesem Artikel richten sich nach dem ISO-Standard. Gelegentlich werden auch andere erweiterte Varianten der BNF als EBNF bezeichnet.&lt;br /&gt;
&lt;br /&gt;
== Grundlagen ==&lt;br /&gt;
Ein Text, etwa [[Quelltext]] eines [[Computerprogramm]]s, besteht zunächst aus [[Terminalsymbol]]en, das heißt, aus sichtbaren Zeichen wie Buchstaben, Ziffern, Satzzeichen, Leerzeichen etc.&lt;br /&gt;
&lt;br /&gt;
Die EBNF definiert [[Produktionsregel]]n, in denen Symbolfolgen jeweils einem Nichtterminalsymbol zugeordnet werden, etwa&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 ZifferAusserNull   = &amp;quot;1&amp;quot; | &amp;quot;2&amp;quot; | &amp;quot;3&amp;quot; | &amp;quot;4&amp;quot; | &amp;quot;5&amp;quot; | &amp;quot;6&amp;quot; | &amp;quot;7&amp;quot; | &amp;quot;8&amp;quot; | &amp;quot;9&amp;quot; ;&lt;br /&gt;
 Ziffer             = &amp;quot;0&amp;quot; | ZifferAusserNull ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
In dieser Produktionsregel wird das Nichtterminalsymbol &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;Ziffer&amp;lt;/span&amp;gt; definiert, das stets auf der linken Seite steht. Der vertikale Strich stellt eine [[Kontravalenz|(exklusive) Alternative]] dar, die Terminalsymbole werden in Anführungszeichen eingeschlossen und mit einem Semikolon als Endezeichen abgeschlossen. Eine &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;Ziffer&amp;lt;/span&amp;gt; ist also eine &amp;#039;&amp;#039;0&amp;#039;&amp;#039; oder eine &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;ZifferAusserNull&amp;lt;/span&amp;gt;, die wiederum eine [[natürliche Zahl]] zwischen &amp;#039;&amp;#039;1&amp;#039;&amp;#039; und &amp;#039;&amp;#039;9&amp;#039;&amp;#039; sein kann.&lt;br /&gt;
&lt;br /&gt;
Eine Produktionsregel kann auch eine Folge von Terminal- oder Nichtterminalsymbolen enthalten, wobei die Bestandteile durch Kommata verbunden werden, etwa:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 Zwoelf                       = &amp;quot;1&amp;quot;, &amp;quot;2&amp;quot; ;&lt;br /&gt;
 Zweihundertundeins           = &amp;quot;2&amp;quot;, &amp;quot;0&amp;quot;, &amp;quot;1&amp;quot; ;&lt;br /&gt;
 Dreihundertzwoelf            = &amp;quot;3&amp;quot;, Zwoelf ;&lt;br /&gt;
 ZwoelfTausendzweihunderteins = Zwoelf, Zweihundertundeins ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ausdrücke, die ausgelassen oder wiederholt werden dürfen, können mit geschweiften Klammern dargestellt { … } werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 NatuerlicheZahl = ZifferAusserNull {, Ziffer } ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Hier passen die Texte &amp;#039;&amp;#039;1&amp;#039;&amp;#039;, &amp;#039;&amp;#039;2&amp;#039;&amp;#039;, …,&amp;#039;&amp;#039;10&amp;#039;&amp;#039;, …,&amp;#039;&amp;#039;12345&amp;#039;&amp;#039;, … . Zu beachten ist, dass alles, was innerhalb der geschweiften Klammern steht, beliebig oft, jedoch auch &amp;#039;&amp;#039;keinmal&amp;#039;&amp;#039; vorkommen kann.&lt;br /&gt;
&lt;br /&gt;
Eine Option kann durch eckige Klammern [ … ] dargestellt werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 GanzeZahl = &amp;quot;0&amp;quot; | [ &amp;quot;-&amp;quot; ], NatuerlicheZahl ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Eine ganze Zahl ist also die Null (&amp;#039;&amp;#039;0&amp;#039;&amp;#039;) oder eine natürliche Zahl, der optional ein Minuszeichen vorangestellt werden kann. Hier passen also alle ganzen Zahlen wie &amp;#039;&amp;#039;0&amp;#039;&amp;#039;, &amp;#039;&amp;#039;-3&amp;#039;&amp;#039;, &amp;#039;&amp;#039;1234&amp;#039;&amp;#039; etc.&lt;br /&gt;
&lt;br /&gt;
Außerdem ist die Möglichkeit vorgesehen, eine definierbare Anzahl an Wiederholungen zu erlauben.&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 LeerzeichenAlsTab = 4 * &amp;quot; &amp;quot; , &amp;quot;Yes&amp;quot; ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Hier wird vor der Zeichenfolge &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;&amp;quot;Yes&amp;quot;&amp;lt;/span&amp;gt; viermal das &amp;quot;&amp;amp;nbsp;&amp;quot;-Zeichen erwartet.&lt;br /&gt;
&lt;br /&gt;
== Motivation zur Erweiterung der BNF ==&lt;br /&gt;
Die BNF benötigt teilweise umständliche Konstrukte, um optionale Elemente, also Elemente, die ausgelassen werden dürfen, sowie sich wiederholende Elemente darzustellen, da sie – anders als die EBNF – nicht &amp;quot;[…]&amp;quot; für Optionen oder &amp;quot;{…}&amp;quot; für optionale Wiederholungen kennt, sondern diese Fälle durch entsprechende Alternativen (mittels &amp;#039;|&amp;#039;-Fällen), Rekursion oder auch &amp;#039;leerem Inhalt&amp;#039; löst.&lt;br /&gt;
&lt;br /&gt;
In der Spezifikation von PL/1 wurden bereits eckige Klammern &amp;quot;[…]&amp;quot; für Optionen verwendet. [[Niklaus Wirth]] hat in der Definition der Sprache [[Pascal (Programmiersprache)|Pascal]] zusätzlich geschweifte Klammern &amp;quot;{…}&amp;quot; für Wiederholungen in die BNF eingeführt und nannte dies &amp;#039;&amp;#039;extended BNF&amp;#039;&amp;#039; (erweiterte BNF).&lt;br /&gt;
&lt;br /&gt;
Alle Formulierungen in einer EBNF-Syntax lassen sich auch in BNF ausdrücken. Die EBNF wurde von Wirth aus Gründen der besseren Lesbarkeit und kompakteren Schreibweise geschaffen.&lt;br /&gt;
&lt;br /&gt;
=== Zahldefinition in BNF ===&lt;br /&gt;
Eine Zahl ist eine Ziffernfolge mit optionalem Minuszeichen als [[Vorzeichen (Zahl)|Vorzeichen]]. In BNF muss man mehrere Alternativen und eine Rekursion für die Ziffernwiederholung verwenden:&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;BNF&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;bnf&amp;quot;&amp;gt;&lt;br /&gt;
 &amp;lt;Zahl&amp;gt; ::= &amp;lt;Positive Zahl&amp;gt; | - &amp;lt;Positive Zahl&amp;gt; | 0&lt;br /&gt;
 &amp;lt;Positive Zahl&amp;gt; ::= &amp;lt;Ziffer ausser Null&amp;gt;&amp;lt;Optionale Ziffernfolge&amp;gt;&lt;br /&gt;
 &amp;lt;Optionale Ziffernfolge&amp;gt; ::= &amp;lt;Ziffer&amp;gt; &amp;lt;Optionale Ziffernfolge&amp;gt; | ε&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Lies: &amp;#039;&amp;#039;Eine Zahl ist entweder eine positive Zahl oder ein Minuszeichen gefolgt von einer positiven Zahl oder das Zeichen Null. Eine positive Zahl ist eine Ziffer außer Null gefolgt von einer optionalen Ziffernfolge. Eine optionale Ziffernfolge ist eine Ziffer gefolgt von einer optionalen Ziffernfolge oder leer.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
=== Zahldefinition in EBNF ===&lt;br /&gt;
In EBNF kann man dies in einer einzigen Regel ohne Rekursion darstellen:&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;EBNF&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 Zahl = ([ &amp;quot;-&amp;quot; ], ZifferAusserNull, { Ziffer }) | &amp;quot;0&amp;quot; ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Lies: &amp;#039;&amp;#039;Eine Zahl besteht aus einem optionalen Minuszeichen, gefolgt von einer Ziffer außer Null, gefolgt von beliebig vielen weiteren Ziffern (auch keiner weiteren Ziffer). Oder: Eine Zahl besteht aus dem Zeichen Null.&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Das Minuszeichen kann weggelassen werden. Die Wiederholung kann auch &amp;#039;&amp;#039;keinmal&amp;#039;&amp;#039; auftreten (optionale Wiederholung). Die EBNF benötigt hier nur eine einzige Regel ohne Alternative, während die BNF drei Regeln mit vier Alternativen benötigt, inklusive einer Rekursion (&amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;&amp;amp;lt;Optionale Ziffernfolge&amp;amp;gt;&amp;lt;/span&amp;gt; enthält sich selbst in der eigenen Definition).&lt;br /&gt;
&lt;br /&gt;
Die EBNF kennzeichnet Terminalsymbole durch Anführungszeichen und verwendet ein Endezeichen. Nichtterminalsymbole werden nicht in spitze Klammern eingeschlossen. Durch die Anführungszeichen sind Verwechslungen ausgeschlossen.&lt;br /&gt;
&lt;br /&gt;
== Andere Ergänzungen und Modifikationen ==&lt;br /&gt;
Die EBNF beseitigt einige Schwachstellen der BNF:&lt;br /&gt;
&lt;br /&gt;
* Die BNF verwendet selbst die Symbole (&amp;amp;lt;, &amp;amp;gt;, |, ::=). Wenn diese in der definierten Sprache auftauchen, kann die BNF nicht ohne Modifikation oder Erklärung verwendet werden.&lt;br /&gt;
* Eine BNF-Syntax kann eigentlich nur einzeilige Regeln enthalten.&lt;br /&gt;
&lt;br /&gt;
Die EBNF löst diese Probleme:&lt;br /&gt;
* [[Terminalsymbol]]e werden grundsätzlich in Anführungszeichen geschrieben (&amp;quot;…&amp;quot; oder &amp;#039;…&amp;#039;). Auf die spitzen Klammern (&amp;quot;&amp;amp;lt;…&amp;amp;gt;&amp;quot;) bei Nichtterminalsymbolen kann dann verzichtet werden.&lt;br /&gt;
* Ein Endezeichen, normalerweise das Semikolon, bei manchen Autoren ein Punkt, kennzeichnet das Ende jeder Regel.&lt;br /&gt;
&lt;br /&gt;
Darüber hinaus sind Erweiterungsmechanismen, Definition der Wiederholungszahl, Herausnehmen von Alternativen (zum Beispiel alle Zeichen ohne Anführungszeichen), Kommentare usw. vorgesehen.&lt;br /&gt;
&lt;br /&gt;
Trotz aller Erweiterungen ist die EBNF nicht „mächtiger“ als die BNF in Hinsicht der Sprachen, die sie definieren kann. Prinzipiell lässt sich jede in EBNF definierte [[Grammatik]] auch durch Regeln in der BNF darstellen, was jedoch häufig in einer wesentlich umfangreicheren Beschreibung resultiert.&lt;br /&gt;
&lt;br /&gt;
Unter Umständen wird auch jede erweiterte BNF als EBNF bezeichnet. So nutzt das [[W3C]] &amp;#039;&amp;#039;eine&amp;#039;&amp;#039; EBNF zur Spezifikation von [[Extensible Markup Language|XML]].&amp;lt;ref&amp;gt;{{cite web | url=http://www.w3c.org/TR/REC-xml#sec-notation | title=Notation | publisher=W3C ®  |  language=englisch | accessdate=2019-04-01}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Kontrollstrukturen ==&lt;br /&gt;
[[Datei:Ebnf-syntax-diagram.png|mini|982x982px|Ein [[Syntaxdiagramm]], das eine Erweiterte Backus-Naur-Form darstellt]]&lt;br /&gt;
Die Sprache kann leicht um [[Kontrollstruktur]]en, arithmetische Ausdrücke und Ein- bzw. Ausgabeanweisungen ergänzt werden. Dann entstünde bereits eine brauchbare, kleine Programmiersprache.&lt;br /&gt;
&lt;br /&gt;
Die folgenden Zeichen, die im ISO/IEC Standard als normale Darstellung empfohlen werden, wurden hier verwendet:&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Verwendung&lt;br /&gt;
!Erklärung&lt;br /&gt;
! Zeichen&lt;br /&gt;
|-&lt;br /&gt;
| Definition&lt;br /&gt;
|&lt;br /&gt;
! =&lt;br /&gt;
|-&lt;br /&gt;
| Aufzählung&lt;br /&gt;
|&lt;br /&gt;
! ,&lt;br /&gt;
|-&lt;br /&gt;
| Endezeichen&lt;br /&gt;
|&lt;br /&gt;
! ;&lt;br /&gt;
|-&lt;br /&gt;
| Alternative&lt;br /&gt;
|Trennt die möglichen Alternativen. Es ist aber als [[exklusives Oder]] zu lesen, da nur das eine oder das andere erlaubt ist. Beides gleichzeitig geht nicht.&lt;br /&gt;
! &amp;lt;nowiki&amp;gt;|&amp;lt;/nowiki&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| Option&lt;br /&gt;
|Umschließt optionale Angaben. Diese Inhalte können, müssen aber nicht gesetzt werden.&lt;br /&gt;
! [ … ]&lt;br /&gt;
|-&lt;br /&gt;
| Optionale Wiederholung&lt;br /&gt;
|Umschlossene Elemente dürfen beliebig oft wiederholt werden. Die Elemente dürfen aber auch ausgelassen werden.&lt;br /&gt;
! { … }&lt;br /&gt;
|-&lt;br /&gt;
| Gruppierung&lt;br /&gt;
|Fasst umschlossene Elemente als eine Einheit zusammen.&lt;br /&gt;
! ( … )&lt;br /&gt;
|-&lt;br /&gt;
| Anführungszeichen, 1. Variante&lt;br /&gt;
|&lt;br /&gt;
! &amp;quot; … &amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
| Anführungszeichen, 2. Variante&lt;br /&gt;
|&lt;br /&gt;
! &amp;#039; … &amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
| Kommentar&lt;br /&gt;
|&lt;br /&gt;
! (* … *)&lt;br /&gt;
|-&lt;br /&gt;
| Spezielle Sequenz&lt;br /&gt;
|&lt;br /&gt;
! ? … ?&lt;br /&gt;
|-&lt;br /&gt;
| Ausnahme&lt;br /&gt;
|&lt;br /&gt;
! -&lt;br /&gt;
|}&lt;br /&gt;
Diese Kontrollstrukturen können auch als [[Syntaxdiagramm]] dargestellt werden. Die Abbildung rechts zeigt einige Beispiele.&lt;br /&gt;
&lt;br /&gt;
== Anwendungen ==&lt;br /&gt;
Viele [[Metasprache]]n, wie beispielsweise [[HTML]] können in der EBNF definiert werden.&amp;lt;ref name=&amp;quot;tomasetti&amp;quot;&amp;gt;Federico Tomassetti: [https://tomassetti.me/ebnf/ EBNF: How to Describe the Grammar of a Language] vom 1. August 2017, abgerufen am 6. August 2019&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Im Prinzip können alle [[Formale Sprache|formalen Sprachen]] in der EBNF ausgedrückt werden. Insbesondere in der Informatik bei der Definition von Programmiersprachen, [[Regulärer Ausdruck|regulären Ausdrücken]] oder [[Parser]]n (siehe zum Beispiel [[Spirit (Parser)|Spirit]]) wird EBNF häufig eingesetzt.&amp;lt;ref&amp;gt;[[Niklaus Wirth]]: &amp;#039;&amp;#039;What can we do about the unnecessary diversity of notation for syntactic definitions?&amp;#039;&amp;#039;, Communications of the ACM, Volume 20, Issue 11, November 1977, 822–823, ACM New York&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
EBNF ist nicht geeignet, um die [[Semantik]] einer Sprache festzulegen. So ist es zum Beispiel ohne weiteres möglich, wesentliche eindeutige Sachverhalte gar nicht oder mehrfach zu definieren, so dass es zu logischen Lücken oder Widersprüchen kommen kann. Ferner kann die [[Zuweisungskompatibilität]] von Ausdrücken durch EBNF nicht festgelegt werden.&amp;lt;ref name=&amp;quot;tomasetti&amp;quot;&amp;gt;&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Beispiele ==&lt;br /&gt;
&lt;br /&gt;
=== Einfache Programmiersprache ===&lt;br /&gt;
Eine ganz einfache Programmiersprache, die nur Zuweisungen erlaubt, kann in EBNF so definiert werden:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
 (* ein einfaches Beispiel in EBNF - Wikipedia *)&lt;br /&gt;
 Programm = &amp;#039;PROGRAM&amp;#039;, Bezeichner ,&lt;br /&gt;
            &amp;#039;BEGIN&amp;#039; ,&lt;br /&gt;
            { Zuweisung, &amp;quot;;&amp;quot; } ,&lt;br /&gt;
            &amp;#039;END&amp;#039;, &amp;quot;.&amp;quot; ;&lt;br /&gt;
 Zuweisung = Bezeichner, &amp;quot;:=&amp;quot;, ( Zahl |&lt;br /&gt;
                               Bezeichner |&lt;br /&gt;
                               String ) ;&lt;br /&gt;
 Bezeichner = Buchstabe, { ( Buchstabe | Ziffer ) } ;&lt;br /&gt;
 Zahl = [ &amp;#039;-&amp;#039; ], Ziffer, { Ziffer } ;&lt;br /&gt;
 String = &amp;#039;&amp;quot;&amp;#039;, { AlleZeichen - &amp;#039;&amp;quot;&amp;#039; }, &amp;#039;&amp;quot;&amp;#039; ;&lt;br /&gt;
 Buchstabe = &amp;quot;A&amp;quot; | &amp;quot;B&amp;quot; | &amp;quot;C&amp;quot; | &amp;quot;D&amp;quot; | &amp;quot;E&amp;quot; | &amp;quot;F&amp;quot; | &amp;quot;G&amp;quot;&lt;br /&gt;
           | &amp;quot;H&amp;quot; | &amp;quot;I&amp;quot; | &amp;quot;J&amp;quot; | &amp;quot;K&amp;quot; | &amp;quot;L&amp;quot; | &amp;quot;M&amp;quot; | &amp;quot;N&amp;quot;&lt;br /&gt;
           | &amp;quot;O&amp;quot; | &amp;quot;P&amp;quot; | &amp;quot;Q&amp;quot; | &amp;quot;R&amp;quot; | &amp;quot;S&amp;quot; | &amp;quot;T&amp;quot; | &amp;quot;U&amp;quot;&lt;br /&gt;
           | &amp;quot;V&amp;quot; | &amp;quot;W&amp;quot; | &amp;quot;X&amp;quot; | &amp;quot;Y&amp;quot; | &amp;quot;Z&amp;quot; ;&lt;br /&gt;
 Ziffer = &amp;quot;0&amp;quot; | &amp;quot;1&amp;quot; | &amp;quot;2&amp;quot; | &amp;quot;3&amp;quot; | &amp;quot;4&amp;quot; | &amp;quot;5&amp;quot; | &amp;quot;6&amp;quot;&lt;br /&gt;
        | &amp;quot;7&amp;quot; | &amp;quot;8&amp;quot; | &amp;quot;9&amp;quot; ;&lt;br /&gt;
 AlleZeichen = ? alle sichtbaren Zeichen ? ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Hier wurden die Standardsymbole (&amp;quot;=&amp;quot; für Definitionen, &amp;quot;;&amp;quot; als Endezeichen usw.) verwendet. Bei Bedarf darf davon abgewichen werden.&lt;br /&gt;
&lt;br /&gt;
Ein syntaktisch zulässiges Programm wäre dann&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;pascal&amp;quot;&amp;gt;&lt;br /&gt;
 PROGRAM DEMO1&lt;br /&gt;
 BEGIN&lt;br /&gt;
   A0:=3;&lt;br /&gt;
   B:=45;&lt;br /&gt;
   H:=-100023;&lt;br /&gt;
   C:=A;&lt;br /&gt;
   D123:=B34A;&lt;br /&gt;
   ESEL:=GIRAFFE;&lt;br /&gt;
   TEXTZEILE:=&amp;quot;Hallo, Welt!&amp;quot;;&lt;br /&gt;
 END.&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Binärbäume ===&lt;br /&gt;
Die Darstellung von [[Binärbaum|Binärbaumen]] in [[Binärbaum#Tiefensuche|pre-order]] als [[Zeichenkette]] kann in EBNF so definiert werden:&amp;lt;syntaxhighlight lang=&amp;quot;ebnf&amp;quot;&amp;gt;&lt;br /&gt;
BinaryTree = Identifier, &amp;quot;(&amp;quot;, BinaryTree, &amp;quot;)(&amp;quot;, BinaryTree, &amp;quot;)&amp;quot; | [Identifier] ;&lt;br /&gt;
Identifier = Letter, { ( Letter | Digit ) } ;&lt;br /&gt;
Letter = &amp;quot;A&amp;quot; | &amp;quot;B&amp;quot; | &amp;quot;C&amp;quot; | &amp;quot;D&amp;quot; | &amp;quot;E&amp;quot; | &amp;quot;F&amp;quot; | &amp;quot;G&amp;quot; | &amp;quot;H&amp;quot; | &amp;quot;I&amp;quot; | &amp;quot;J&amp;quot; | &amp;quot;K&amp;quot; | &amp;quot;L&amp;quot; | &amp;quot;M&amp;quot; | &amp;quot;N&amp;quot; | &amp;quot;O&amp;quot; | &amp;quot;P&amp;quot; | &amp;quot;Q&amp;quot; | &amp;quot;R&amp;quot; | &amp;quot;S&amp;quot; | &amp;quot;T&amp;quot; | &amp;quot;U&amp;quot; | &amp;quot;V&amp;quot; | &amp;quot;W&amp;quot; | &amp;quot;X&amp;quot; | &amp;quot;Y&amp;quot; | &amp;quot;Z&amp;quot; ;&lt;br /&gt;
Digit = &amp;quot;0&amp;quot; | &amp;quot;1&amp;quot; | &amp;quot;2&amp;quot; | &amp;quot;3&amp;quot; | &amp;quot;4&amp;quot; | &amp;quot;5&amp;quot; | &amp;quot;6&amp;quot; | &amp;quot;7&amp;quot; | &amp;quot;8&amp;quot; | &amp;quot;9&amp;quot; ;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;[[Datei:Sorted binary tree.svg|mini|Ein [[Binärbaum]]]]Der [[Binärbaum]] rechts hat dann die [[Binärbaum#Tiefensuche|pre-order]] Darstellung &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;F(B(A)(D(C)(E)))(G()(I(H)()))&amp;lt;/span&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Die [[Produktionsregel|Produktionsregeln]] dieser EBNF können auch wie folgt dargestellt werden:&lt;br /&gt;
:&amp;lt;math&amp;gt;\begin{align}&lt;br /&gt;
S &amp;amp; \rightarrow I(S)(S) \\&lt;br /&gt;
S &amp;amp; \rightarrow I \\&lt;br /&gt;
S &amp;amp; \rightarrow \varepsilon \\&lt;br /&gt;
I &amp;amp; \rightarrow LE \\&lt;br /&gt;
E &amp;amp; \rightarrow LE \\&lt;br /&gt;
E &amp;amp; \rightarrow DE \\&lt;br /&gt;
E &amp;amp; \rightarrow \varepsilon \\&lt;br /&gt;
L &amp;amp; \rightarrow \mathrm{A} \\&lt;br /&gt;
L &amp;amp; \rightarrow \mathrm{B} \\&lt;br /&gt;
  &amp;amp; \cdots \\&lt;br /&gt;
L &amp;amp; \rightarrow \mathrm{Z} \\&lt;br /&gt;
D &amp;amp; \rightarrow 0 \\&lt;br /&gt;
D &amp;amp; \rightarrow 1 \\&lt;br /&gt;
  &amp;amp; \cdots \\&lt;br /&gt;
D &amp;amp; \rightarrow 9 \\&lt;br /&gt;
\end{align}&lt;br /&gt;
&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Die Menge der Terminalsymbole ist &amp;lt;math&amp;gt;T = \{ (, ), \mathrm{A}, \mathrm{B}, \ldots, \mathrm{Z}, 0, 1, \ldots, 9 \}&lt;br /&gt;
&amp;lt;/math&amp;gt;, die Menge der Nichtterminalsymbole ist &amp;lt;math&amp;gt;N = \{ S, I, E, L, D \}&lt;br /&gt;
&amp;lt;/math&amp;gt; und das Startsymbol ist &amp;lt;math&amp;gt;S&lt;br /&gt;
&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Backus-Naur-Form]]&lt;br /&gt;
* [[Angereicherte Backus-Naur-Form]]&lt;br /&gt;
* [[Kontextfreie Grammatik]]&lt;br /&gt;
* [[Kellerautomat]]&lt;br /&gt;
* [[Syntaxdiagramm]]&lt;br /&gt;
* vereinfachte Programmiersprache [[PL/0]] als EBNF-Muster&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* SELFHTML: [https://wiki.selfhtml.org/wiki/Backus_Naur_Form &amp;#039;&amp;#039;Backus Naur Form&amp;#039;&amp;#039;]&lt;br /&gt;
* GeeksforGeeks: [https://www.geeksforgeeks.org/bnf-notation-in-compiler-design/ &amp;#039;&amp;#039;BNF Notation in Compiler Design&amp;#039;&amp;#039;]&lt;br /&gt;
* Christian-Albrechts-Universität zu Kiel: [https://www.informatik.uni-kiel.de/~mh/lehre/pps20/vorlesung/kap21.pdf &amp;#039;&amp;#039;EBNF (Erweiterte Backus-Naur-Form)&amp;#039;&amp;#039;]&lt;br /&gt;
* [https://www.cl.cam.ac.uk/~mgk25/iso-14977.pdf ISO/IEC &amp;#039;&amp;#039;14977: 1996(E) – ISO-Standard zu EBNF (final draft version SC22/N2249)&amp;#039;&amp;#039;] (PDF) Anmerkung: „Dieses Dokument ist ein Entwurf, der noch Fehler enthält. ‚Meta-Identifiers‘ etwa werden im Text mit Bindestrichen verbunden (siehe Abschnitt 4: “written as one or more words joined together by hyphens”), in den Beispielen hingegen werden bis auf einige Kommentare diese Meta-Identifiers mit Leerzeichen geschrieben.“ Anmerkung 2: „In den Beispielen können (bis auf eben in den Kommentaren) die Bindestriche gar nicht verwendet werden, da diese das ‚Except-Symbol‘ repräsentieren und man dadurch die im Dokument spezifizierten EBNF-Syntaxregeln verletzte…“ (PDF-Datei; 79 kB)&lt;br /&gt;
* [https://standards.iso.org/ittf/PubliclyAvailableStandards/s026153_ISO_IEC_14977_1996(E).zip &amp;#039;&amp;#039;ISO/IEC 14977: 1996(E) – ISO-Standard zu EBNF (1st Edition)&amp;#039;&amp;#039;] (ZIP-komprimiertes PDF, 2,2 MB)&lt;br /&gt;
* [https://www.cs.man.ac.uk/~pjj/bnf/ebnf.html &amp;#039;&amp;#039;Varianten der BNF und EBNF im Überblick&amp;#039;&amp;#039;]&lt;br /&gt;
* [https://karmin.ch/ebnf/index &amp;#039;&amp;#039;EBNF Parser &amp;amp; Renderer&amp;#039;&amp;#039;] auf Basis PHP&lt;br /&gt;
* [https://github.com/Weltraumschaf/ebnf &amp;#039;&amp;#039;Parser &amp;amp; Renderer in PHP5&amp;#039;&amp;#039;]&lt;br /&gt;
* {{Webarchiv|url=http://www-cgi.uni-regensburg.de/~brf09510/grammartypes.html|wayback=20101030132932|text=&amp;#039;&amp;#039;Vergleich der BNF-Varianten&amp;#039;&amp;#039; (englisch)}}&lt;br /&gt;
* {{Webarchiv|url=http://homepages.uni-regensburg.de/~brf09510/syntax.html|wayback=20111201001222|text=&amp;#039;&amp;#039;Erzeugen von Syntaxdiagrammen aus EBNF&amp;#039;&amp;#039;}}&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Compilerbau]]&lt;br /&gt;
[[Kategorie:Theorie formaler Sprachen]]&lt;/div&gt;</summary>
		<author><name>imported&gt;SchlurcherBot</name></author>
	</entry>
</feed>