data:image/s3,"s3://crabby-images/c4b6c/c4b6c55acb3728dc87166776526aa3109e755207" alt="SDSU" |
CS 635: Advanced Object-Oriented Design & Programming |
|
---|
Spring Semester, 1998
Decorator
To Lecture Notes Index
© 1998, All Rights Reserved, SDSU & Roger Whitney
San Diego State University -- This page last updated 21-Apr-98
Contents of Doc 23, Decorator
CS 635 Doc 23 Decorator
References | slide # 1 |
| |
Decorator | slide # 2 |
...Solution 2 - Use Decorator | slide # 5 |
...Applicability | slide # 6 |
...Consequences | slide # 6 |
...Implementation Issues | slide # 7 |
...Java Example of Decorator -
Streams | slide # 8 |
References
Design Patterns: Elements of Reusable Object-Oriented
Software, Gamma, Helm, Johnson, Vlissides, Addison
Wesley, 1995, pp 175-184
Decorator
Changing the Skin of an Object
Class Structure
data:image/s3,"s3://crabby-images/455e7/455e736ac6667aa61bbe4c36368721a754475cf8" alt="Decorator Class Structure"
Runtime Structure
data:image/s3,"s3://crabby-images/33f89/33f89d07f1147252d8844524295a7bd3fd525839" alt="Decorator Runtime Structure"
Motivation - Text Views
A text view has the following features:
- side scroll bar
- bottom scroll bar
- 3D border
- Flat border
This gives 12 different options:
- TextView
- TextViewWithNoBorder&SideScrollbar
- TextViewWithNoBorder&BottomScrollbar
- TextViewWithNoBorder&Bottom&SideScrollbar
- TextViewWith3DBorder
- TextViewWith3DBorder&SideScrollbar
- TextViewWith3DBorder&BottomScrollbar
- TextViewWith3DBorder&Bottom&SideScrollbar
- TextViewWithFlatBorder
- TextViewWithFlatBorder&SideScrollbar
- TextViewWithFlatBorder&BottomScrollbar
- TextViewWithFlatBorder&Bottom&SideScrollbar
How to implement?
Solution 1 - Use Object Composition
data:image/s3,"s3://crabby-images/42493/42493f770bba9a15ce35063ada15e8bb1494b1f7" alt="Text View classes using Strategy like Composition"
class TextView
{
Border myBorder;
ScrollBar verticalBar;
ScrollBar horizontalBar;
public void draw()
{
myBorder.draw();
verticalBar.draw();
horizontalBar.draw();
code to draw self
}
etc.
}
But TextView know about all the variations!
New type of variations require changing TextView
(and any other type of view we have)
Solution 2 - Use Decorator
Object Composition Inside out
Change the skin of an object not it guts
TextView has no borders or scrollbars!
Add borders and scrollbars on top of a TextView
data:image/s3,"s3://crabby-images/a45a9/a45a9e6ededde571c1614793d40c22d6d859791a" alt="Text View using Decorator Pattern"
Runtime Structure
data:image/s3,"s3://crabby-images/a5463/a546338cd6630ce002217beb4730d416f57e3b7a" alt="Text View Decorator Objects"
Applicability
Use Decorator:
- to add responsibilities to individual objects dynamically and
transparently
- for responsibilities that can be withdrawn
- when subclassing is impractical - may lead to too many
subclasses
Consequences
More flexible than static inheritance
Avoids feature laden classes high up in hierarchy
Lots of little objects
A decorator and its components are not identical
- so checking object identification can cause problems
if ( aComponent instanceof TextView ) blah
Implementation Issues
Keep Decorators lightweight
Don't put data members in VisualComponent
data:image/s3,"s3://crabby-images/a45a9/a45a9e6ededde571c1614793d40c22d6d859791a" alt=""
Java Example of Decorator - Streams
data:image/s3,"s3://crabby-images/18c12/18c12b3ba0526b586217dcd93f99e5fedb0359f7" alt=""
import java.io.*;
import sdsu.io.*;
class ReadingFileExample
{
public static void main( String args[] ) throws Exception
{
FileInputStream inputFile;
BufferedInputStream bufferedFile;
ASCIIInputStream cin;
inputFile = new FileInputStream( "ReadingFileExample.java" );
bufferedFile = new BufferedInputStream( inputFile );
cin = new ASCIIInputStream( bufferedFile );
System.out.println( cin.readWord() );
for ( int k = 1 ; k < 4; k++ )
System.out.println( cin.readLine() );
}
}
© 1998, All Rights Reserved, SDSU & Roger Whitney
visitors since 21-Apr-98