Parser

Aus SibiWiki
Zur Navigation springen Zur Suche springen



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());
   }
}