Parser
Version vom 3. Februar 2015, 10:36 Uhr von Akaibel (Diskussion | Beiträge) (Die Seite wurde neu angelegt: „Ein '''Parser''' zu einer Grammatik ist ein Algorithmus, mit dem sich überprüfen lässt, ob ein Wort zu der von der Grammatik erzeugten Sprache gehört, d.h.…“)
Ein Parser zu einer Grammatik ist ein Algorithmus, mit dem sich überprüfen lässt, ob ein Wort zu der von der Grammatik erzeugten Sprache gehört, d.h. ob es syntaktisch korrekt ist. Der Algorithmus lässt sich dann in Java implementieren.
Man könnte auch sagen: Ein Parser simuliert den zu der Grammatik gehörenden Automaten.
Beispiel
Es soll ein Parser für den KGB-Automaten erstellt werden.
Der KGB-Automat erkennt Wörter, die nur aus den Ziffern 0,...,9 bestehen und die irgendwo die Zahlenkette "007" enhalten.
Implementierung
import gui.GUI;
public class KGBAutomat {
private char[] alphabet = {'0', '1', '2','3','4','5','6','7','8','9'};
public boolean imAlphabet(char pZeichen){
for(char zeichen: alphabet){
if(zeichen == pZeichen){
return true;
}
}
return false;
}
public boolean parse(String pWort){
int zustand = 0;
for(char zeichen: pWort.toCharArray()){
if(!imAlphabet(zeichen)){
return false;
}
switch(zustand){
case 0: switch(zeichen){
case '0': zustand = 1; continue;
default: zustand = 0; continue;
}
case 1: switch(zeichen){
case '0': zustand = 2; continue;
default: zustand = 0; continue;
}
case 2: switch(zeichen){
case '0': zustand = 2; continue;
case '7': zustand = 3; continue;
default: zustand = 0; continue;
}
case 3: switch(zeichen){
default: zustand = 3; continue;
}
}
}
return (zustand == 3);
}
public static void main(String[] args) {
new GUI(new KGBAutomat());
}
}