Die BNF benötigt teilweise umständliche Konstrukte, um optionale Elemente, also Elemente, die ausgelassen werden dürfen, sowie sich wiederholende Elemente, darzustellen. In der Spezifikation von PL/1 wurden bereits eckige Klammern "[...]" für Optionen eingeführt. Niklaus Wirth hat in der Definition der Sprache Pascal zusätzlich geschweifte Klammern "{..._}" für Wiederholungen in die BNF eingeführt und nannte dies extended BNF (erweiterte BNF).
Eine Zahl ist eine Ziffernfolge mit optionalem Minuszeichen als Vorzeichen. In BNF muss man mehrere Alternativen und eine Rekursion für die Ziffernwiederholung verwenden:
Lies: Eine Zahl ist entweder eine positive Zahl oder ein Minuszeichen gefolgt von einer positiven Zahl. Eine positive Zahl ist entweder eine Ziffer oder eine Ziffer gefolgt von einer positiven Zahl.
In EBNF kann man dies in einer einzigen Regel ohne Rekursion darstellen:
EBNF
Zahl = [ '-' ] Ziffer { Ziffer } ;
Lies: Eine Zahl ist ein optionales Minuszeichen, gefolgt von einer Ziffer, gefolgt von keiner oder beliebig vielen weiteren Ziffern.
Das Minuszeichen kann weggelassen werden. Die Wiederholung kann auch keinmal auftreten (optionale Wiederholung). Die EBNF benötigt hier nur eine einzige Regel ohne Alternative, während die BNF zwei Regeln mit vier Alternativen benötigt, inklusive einer Rekursion (<Positive Zahl> enthält sich selbst in der eigenen Definition).
Andere Ergänzungen und Modifikationen
Zusätzlich beseitigt die EBNF einige Schwachstellen der BNF:
Die BNF verwendet selbst die Symbole (<, >, |, ::=). Wenn diese in der definierten Sprache auftauchen, kann die BNF nicht ohne Modifikation oder Erklärung verwendet werden.
Eine BNF-Syntax kann eigentlich nur einzeilige Regeln enthalten.
Die EBNF löst diese Probleme:
Terminalsymbole werden grundsätzlich in Anführungszeichen geschrieben ("..." oder '...'). Auf die spitzen Klammern ("<..._>") bei Nichtterminalsymbolen kann dann verzichtet werden.
Ein Endezeichen, normalerweise das Semikolon, kennzeichnet das Ende jeder Regel.
Darüberhinaus sind Erweiterungsmechanismen, Definition der Wiederholungszahl, Herausnehmen von Alternativen (zum Beispiel alle Zeichen ohne Anführungszeichen), Kommentare usw. vorgesehen.
Trotz aller Erweiterungen ist die EBNF nicht "mächtiger" als die BNF in Hinsicht der Sprachen, die sie definieren kann. Prinzipiell ließe sich jede in EBNF definierte Grammatik auch nach BNF übertragen, allerdings mit vermutlich wesentlich höherem Aufwand.
Die EBNF ist von der ISO standardisiert unter der Nummer ISO/IEC 14977:1996(E). Manchmal wird auch jede BNF, die mindestens um eckige Klammern für Optionen und geschweifte Klammern für optionale Wiederholung ergänzt wurde, als EBNF bezeichnet.
Beispiel
Eine ganz einfache Programmiersprache, die nur Zuweisungen erlaubt, kann in EBNF so definiert werden:
Hier wurden die Standardsymbole ("=" für Definitionen, ";" als Endezeichen usw.) verwendet. Bei Bedarf darf davon abgewichen werden.
Ein syntaktisch zulässiges Programm wäre dann
PROGRAM DEMO1
BEGIN
A0:=3;
B:=45;
H:=-100023;
C:=A;
D123:=B34A;
ESEL:=GIRAFFE;
TEXTZEILE:="Hallo, Welt!"
END.
Die Sprache kann leicht um Kontrollstrukturen, arithmetische Ausdrücke und Ein- beziehungsweise Ausgabeanweisungen ergänzt werden. Dann entstünde bereits eine brauchbare, kleine Programmiersprache.
Die folgenden Zeichen, die im Standard als normale Darstellung empfohlen werden, wurden hier verwendet:
Dieser Beitrag ist aus der XML-Version der deutschen WikiPedia® entwickelt worden und unterliegt inhaltlich den GNU FDL-Lizenzbestimmungen. Linkziele außerhalb der wikipedia-Inhalte unterliegen den Urheberrechten der jeweiligen Anbieter
( DirectDownloads ) Kalenderblätter druckfertig aufbereitet für Schmuckblätter zum Selbstdrucken im Word DOC6/RTF Format, je Euro 5 über Click&BuyJAN | FEB | MÄRZ APRIL | MAI | JUNI JULI | AUG | SEPT OKT | NOV | DEZ
Das Geschenk für jeden Anlass, nicht nur bei 'runden' Jubiläen Andere Einzeltage oder Zahlungsarten bitte HIER bestellen
Diese Web Site verdient ihr Geld durch Produktverkäufe (CD-ROM, downloads) und in erster Linie durch Anzeigen. Wenn Sie als Webmaster zuverlässige Partner suchen für Ihr eigenes Anzeigenschäft, dürfen Sie sich gerne auf unsere Empfehlungen stützen:
z.B.: GigaCash & ProfiWin