Visitor Pattern - State

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:

    A work in progress quickly becomes feral. It reverts to a wild state overnight. It is barely domesticated, a mustang on which you one day fastened a halter, but which now you cannot catch. It is a lion you cage in your study. As the work grows, it gets harder to control; it is a lion growing in strength. You must visit it every day and reassert your mastery over it. If you skip a day, you are, quite rightly, afraid to open the door to its room.
    Annie Dillard (b. 1945)

    The state does not demand justice of its members, but thinks that it succeeds very well with the least degree of it, hardly more than rogues practice; and so do the neighborhood and the family. What is commonly called Friendship even is only a little more honor among rogues.
    Henry David Thoreau (1817–1862)

    A State, in idea, is the opposite of a Church. A State regards classes, and not individuals; and it estimates classes, not by internal merit, but external accidents, as property, birth, etc. But a church does the reverse of this, and disregards all external accidents, and looks at men as individual persons, allowing no gradations of ranks, but such as greater or less wisdom, learning, and holiness ought to confer. A Church is, therefore, in idea, the only pure democracy.
    Samuel Taylor Coleridge (1772–1834)