State
Aside from potentially improving separation of concerns, the visitor pattern has an additional advantage over simply calling a polymorphic method: a visitor object can have state. This is extremely useful in many cases where the action performed on the object depends on previous such actions.
An example of this is a pretty-printer in a programming language implementation (such as a compiler or interpreter). Such a pretty-printer object (implemented as a visitor, in this example), will visit nodes in a data structure that represents a parsed and processed program. The pretty-printer will then generate a textual representation of the program tree. To make the representation human-readable, the pretty-printer should properly indent program statements and expressions. The current indentation level can then be tracked by the visitor as its state, correctly applying encapsulation, whereas in a simple polymorphic method invocation, the indentation level would have to be exposed as a parameter and the caller would rely on the method implementation to use and propagate this parameter correctly.
Read more about this topic: Visitor Pattern
Famous quotes containing the word state:
“Utah is the only State that gives condemned men a choice between death by hanging or before a firing squad. Most prisoners prefer the firing squad, but one obstinate convict in 1912 elected to be hanged because hanging is more expensive to the state.”
—State of Utah, U.S. public relief program (1935-1943)
“The nonconformist and the rebel say all manner of unanswerable things against the existing republic, but discover to our sense no plan of house or state of their own.”
—Ralph Waldo Emerson (18031882)
“D--n me, stranger, ef you cant stay as long as you please, and Ill give you plenty to eat and drink. Play away, stranger, you kin sleep on the dry spot tonight!”
—Administration in the State of Arka, U.S. public relief program (1935-1943)