Applied Design Patterns with Java
Behavioral :: Interpreter (243) {C ch 18}
Example - Java :: Patterns\Behavioral\Interpreter
Pattern Concept: to define a grammar for a language, and use that grammar to interpret statements in the
language. The Interpreter pattern drives three use cases:
- When a command Interpreter is needed to
parse user commands that allow a query facility that returns different results, based on the parsed input.
- When a program must parse an algebraic string, a common
occurrence in math and graphics packages.
- When a program must produce varied output different from
how the input is stored or represented, i.e.: like a Report Generator, or Traffic Analyzer, etc.
Interpreting a language takes three steps:
- parsing language symbols into tokens
- reducing the tokens into actions
- executing the actions
Examples - UML : SimpleParse and InterpDemo
Here is a sample parse output,
with a diagram showing the parse reduction, and the representive classes to accomplish this in UML:
data:image/s3,"s3://crabby-images/6c451/6c45108305af3d73984cebe62a993980fc2a183a" alt=""
data:image/s3,"s3://crabby-images/31c54/31c549727efd65171e259c35eb9e4ec2b906320e" alt=""
data:image/s3,"s3://crabby-images/bd733/bd7330ed38a18ce3ab5804f89e8b72ff1c8d8b84" alt=""
Here is Cooper's Class Diagram for the application using this logic,
followed by the Rose equivalent:
data:image/s3,"s3://crabby-images/a8387/a8387047bc8a12569fa888b956886ab28082fb47" alt=""
data:image/s3,"s3://crabby-images/982c3/982c39c30bfa8cdf69afff95e66b0f82b1627a21" alt=""
The example Java program is called 'InterpDemo'.
The UML diagram is above, and the list of Java files is
below:
data:image/s3,"s3://crabby-images/72684/7268452e0b8d4c348581c993b6056840ac1bc70f" alt=""
Issues and consequences of the Interpreter
pattern include:
- When an Interpreter
is used, an easy mechanism for the user to enter
commands in the language must be furnished;
- Generating a language and its grammar are non-trivial tasks,
requiring care and extensive testing, and the issue of what happens when a user enters a string that violates the
grammar
must be handled robustly and in a user-friendly manner;
- Even a GUI has an implied grammar behind it (proper values and sequencing of user actions in a given panel);
- The Interpreter
pattern has the advantage of being readily extensible, and a
grammar
can be revised, once the mechanism of parsing and reducing are fully understood and implemented;
- For grammars of any complexity (greater than six cases), use a class for each case. A large
grammar
may have many classes associated with it;
- Adding more complexity to a grammar is self-defeating; at some point, the grammar may become too complex to readily maintain.
Catalog Behavioral Prev Next