Two decorators (classmethod() and staticmethod()) have been available in Python since version 2.2. It's been assumed since approximately that time that some syntactic support for them would eventually be added to the language. Given this assumption, one might wonder why it's been so difficult to arrive at a consensus. Discussions have raged off-and-on at times in both comp.lang.python and the python-dev mailing list about how best to implement function decorators. There is no one clear reason why this should be so, but a few problems seem to be most divisive.
Water miscible oil paints (also called "water soluble" or "water-mixable") is a modern variety of oil paint engineered to be thinned and cleaned up with water, rather than having to use chemicals such as turpentine. It can be mixed and applied using the same techniques as traditional oil-based paint, but while still wet it can be effectively removed from brushes, palettes, and rags with ordinary soap and water. Its water solubility comes from the use of an oil medium in which one end of the molecule has been altered to bind loosely to water molecules, as in a solution.
Speed, portability and permanence also make aerosol paint a common graffiti medium. In the late 1970s, street graffiti writers' signatures and murals became more elaborate and a unique style developed as a factor of the aerosol medium and the speed required for illicit work. Many now recognize graffiti and street art as a unique art form and specifically manufactured aerosol paints are made for the graffiti artist. A stencil protects a surface, except the specific shape to be painted. Stencils can be purchased as movable letters, ordered as professionally cut logos or hand-cut by artists.
Now, assume one also desires the ability to add borders to windows. Again, the original Window class has no support. The ScrollingWindow subclass now poses a problem, because it has effectively created a new kind of window. If one wishes to add border support to many but not all windows, one must create subclasses WindowWithBorder and ScrollingWindowWithBorder etc. This problem gets worse with every new feature or window subtype to be added. For the decorator solution, we simply create a new BorderedWindowDecorator—at runtime, we can decorate existing windows with the ScrollingWindowDecorator or the BorderedWindowDecorator or both, as we see fit. Notice that if the functionality needs to be added to all Windows, you could modify the base class and that will do. On the other hand, sometimes (e.g., using external frameworks) it is not possible, legal, or convenient to modify the base class.

This difference becomes most important when there are several independent ways of extending functionality. In some object-oriented programming languages, classes cannot be created at runtime, and it is typically not possible to predict, at design time, what combinations of extensions will be needed. This would mean that a new class would have to be made for every possible combination. By contrast, decorators are objects, created at runtime, and can be combined on a per-use basis. The I/O Streams implementations of both Java and the .NET Framework incorporate the decorator pattern.

Some commonly used decorators that are even built-ins in Python are @classmethod, @staticmethod, and @property. The @classmethod and @staticmethod decorators are used to define methods inside a class namespace that are not connected to a particular instance of that class. The @property decorator is used to customize getters and setters for class attributes. Expand the box below for an example using these decorators.
Painters work both indoors and out. Outside work is done in relatively mild weather. In some jobs, especially maintenance and redecoration of offices and buildings, the painter may be required to work evenings or weekends. Work is seasonal; however, new materials and methods tend to give more steady employment throughout the year. Physical and health hazards include the dangers of poisoning, falling from ladders and scaffolds, breathing paint fumes and dust. The work involves standing, bending, climbing and working with arms over the head much of the time.
Decorator Abstractions: A decorator abstraction is an abstract class that implements the component interface. Critically, the decorator abstraction must also contain a pointer to some instance of the same interface. Inside the decorator abstraction, each of the component interface behaviors will be delegated to whichever concrete component the pointer indicates.
The container must inject a delegate object to the delegate injection point. The delegate object implements the delegate type and delegates method invocations to remaining uninvoked decorators and eventually to the bean. When the container calls a decorator during business method interception, the decorator may invoke any method of the delegate object.
By downloading this trial product, you agree to receive marketing communications from us and/or our suppliers. You may opt-out of receiving such future emails by clicking the unsubscribe link in any email you receive, or by signing into your Corel account through our website using your email address and password, and clicking on Manage Your Communication Preferences.
×