1.1. Intent ¶
ν΄λμ€μ μΈν°νμ΄μ€λ₯Ό λ€λ₯Έ νμν ν΄λμ€μ μΈν°νμ΄μ€μ λ§κ² λ³νν΄μ€λ€. Adapter λ μλ‘ νΈνμ±μ΄ μλ μΈν°νμ΄μ€λ€λΌλ¦¬λΌλ κ°μ΄ μλν  μ μκ²λ ν΄μ€λ€.
1.4. Applicability ¶
λ€μκ³Ό κ°μ κ²½μ°μ AdapterPatternλ₯Ό μ΄μ©νλ€.
- μ΄λ―Έ λ§λ€μ΄μ Έ μλ ν΄λμ€λ₯Ό μ¬μ©νκ³  μΆμ§λ§, μΈν°νμ΄μ€κ° μνλ λ°©μκ³Ό μΌμΉνμ§ μμλ.
 
- κ΄λ ¨μ±μ΄ μκ±°λ, μμΈ‘νμ§ λͺ»ν ν΄λμ€λ€κ³Ό νλνλ μ¬μ¬μ©κ°λ₯ν ν΄λμ€λ₯Ό μμ±νκΈ° μν λ. μ΄ κ²½μ° ν΄λμ€λ€μ΄ νΈνμ±μ κ°μ§λ μΈν°νμ΄μ€λ₯Ό νμλ‘ νμ§ μλλ€.
 
- (object adapter μ κ²½μ°μλ§ ν΄λΉ) νμ¬ μ΄λ―Έ λ§λ€μ΄μ§ μ¬λ¬κ°μ subclassκ° νμν κ²½μ°, νμ§λ§ κ°κ°μ μλΈν΄λμ€λ€μ λν μΈν°νμ΄μ€λ₯Ό νλ κ²μ λΉν¨μ¨μ μ΄λ€. μ΄ κ²½μ° parent classμ μΈν°νμ΄μ€λ₯Ό adapt ν  μ μλ€. 
 
 
1.5. Structure ¶
adapter ν΄λμ€λ νλμ interfaceλ₯Ό λ€λ₯Έ interface μ μ ν©νκ² λ§μΆ°μ£ΌκΈ° μν΄ (λ§ κ·Έλλ‘ μ΄λν° μν ~) λ€μ€μμμ μ΄μ©νλ€.
adapter κ°μ²΄λ object composition μ μμ‘΄νλ€.
1.6. Participants ¶
- Target (Shape)
 - ν΄λΌμ΄μΈνΈκ° μ΄μ©ν domain-specificν μΈν°νμ΄μ€λ₯Ό μ μνλ€.
 
- Client (DrawingEditor)
 - Targetμ μΈν°νμ΄μ€μ λ°λΌ κ°μ²΄λ€κ³Ό μνΈμμ©μ νλ€.
 
- Adaptee (TextView)
 - adaptingμ΄ νμν νμ‘΄νλ interfaceλ₯Ό μ μνλ€.
 
- Adapter (TextShape)
 - Adpatee μ μΈν°νμ΄μ€λ₯Ό Target μ μΈν°νμ΄μ€μ adapt μν¨λ€.
 
 
1.7. Collaborations ¶
- ν΄λΉ ν΄λμ€λ₯Ό μ΄μ©νλ Clientλ€μ Adapter μΈμ€ν΄μ€μ operationλ€μ νΈμΆνλ€. adapterλ ν΄λΉ Clientμ μμ²μ μννκΈ° μν΄ Adaptee μ operationμ νΈμΆνλ€.
 
 
1.9. Implementation ¶
~cpp directoryDisplay := (TreeDisplay on: treeRoot) getChildrenBlock: [:node | node getSubdirectories] createGraphicNodeBlock: [:node | node createGraphicNode].
1.10. Sample Code ¶
We'll give a brief sketch of the implementation of class and object adapters for the Motivation example beginning with the classes Shape and TextView.
~cpp 
class Shape {
public:
	Shape ();
	virtual void BoundingBox(Point& bottomLeft, Point& topRight) const;
	virtual Manipulator* CreateManipulator () const;
};
class TextView {
public:
	TextView ();
	void GetOrigin (Coord& x, Coord& y) const;
	void GetExtent (Coord& width, Coord& height) const;
	virtual bool IsEmpty () const;
Shape assumes a bounding box defined by its opposing corners. In contrast, TextView is defined by an origin, height, and width. Shape also defines a CreateManipulator operation for creating a Manipulator object, which knowns how to animate a shape when the user manipulates it. TextView has no equivalent operation. The class TextShape is an adapter between these different interfaces.
A class adapter uses multiple inheritance to adapt interfaces. The key to class dapters is to use one inheritance branch to inherit the interface and another branch to inherit the implementation. The usual way to make this distinction in C++ is to inherit the interface publicly and inherit the implementation privately. We'll use this convention to define the TextShape adapter.
~cpp 
class TextShape : public Shape, private TextView {
public:
	TextShape ();
	virtual void BoundingBox (Point& bottomLeft, Point& topRight) const;
	virtual bool IsEmpty () const;
	virtual Manipulator* CreateManipulator () const;
};
The BoundingBox operation converts TextView's interface to conform to Shape's.
~cpp 
void TextShape::boundingBox (Point& bottomLeft, Point& topRight) const {
	Coord bottom, left, width, height;
	GetOrigin (bottom, left);
	GetExtent (width, height);
	bottomLeft = Point (bottom, left);
	topRight = Point (bottom + height, left + width);
The IsEmpty operations demonstrates the direct forwarding of requests common in adapter implementations:
~cpp 
bool TextShape::ImEmpty () const {
	return TextView::IsEmpty ();
}
Finally, we define CreateManipulator (which isn't supported by TextView) from scratch. Assume we've already implemented a TextManipulator class that supports manipulation of a TextShape.
~cpp 
Manipulator* TextShape::CreateManipulator () const {
	return new TextManipulator (this);
The object adapter uses object composition to combine classes with different interfaces. In this approach, the adapter TextShape maintains a pointer to TextView.
~cpp 
class TextShape : public Shape {
public:
	TextShape (TextView*);
	virtual void BoundingBox (Point& bottomLeft, Point& topRight) const;
	virtual bool IsEmpty () const;
	virtual Manipulator* CreateManipulator () const;
private:
	TextView* _text;
};
TextShape must initialize the pointer to the TextView instance, and it does so in the constructor. It must also call operations on its TextView object whenever its own operations are called. In this example, assume that the client creates the TextView object and passes it to the TextShape constructor.
~cpp 
TextShape::TextShape (TextView* t) {
	_text = t;
}
void TextShape::BoundingBox (
	Point& bottomLeft, Point& topRight
) const {
	Coord bottom, left, width, height;
	_text->GetOrigin (bottom, left);
	_text->GetExtent (width, height);
	bottomLeft = Point (bottom, left);
	topRight = Point (bottom + height, left + width);
}
bool TextShape::IsEmpty () const {
	return _text->IsEmpty ();
}
CreateManipulator's implementation doesn't change from the class adapter version, since it's implemented from scratch and doesn't reuse any existing TextView functionality.
~cpp 
Manipulator* TextShape::CreateManipulator () const {
	return new TextManipulator (this);
}
Compare this code the class adapter case. The object adapter requires a little more effort to write, but it's more flexible. For example, the object adapter version of TextShape will work equally well with subclasses of TextView -- the client simply passes an instance of a TextView subclass to the TextShape constructor.
1.12. Related Patterns ¶
BridgePattern μ adapter objectμ λΉμ·ν ꡬ쑰λ₯Ό κ°μ§λ€. νμ§λ§ BridgePatternμ AdapterPatternκ³Ό κ·Έ μλκ° λ€λ₯΄λ€. BridgePatternμ μ€μ  ꡬνλΆμ interfaceλΆλΆμ λΆλ¦¬μμΌ μ€μ  ꡬν λΆλΆμ΄ λ€μνκ³  λ
립μ μΌ μ μλλ‘ νκΈ° μν κ²μ΄λ€. adapterλ νμ¬ μ΄λ―Έ μ‘΄μ¬νλ κ°μ²΄μ λν interfaceλ₯Ό λ°κΎΈκΈ° μν΄ μ΄μ©λλ€.
DecoratorPatternμ κ°μ²΄μ λν μΈν°νμ΄μ€μ λ³νμμ΄ κ°μ²΄λ₯Ό νμ₯μν¨λ€. Decorator λ adapterλ³΄λ€ λ applicationμ λν΄ ν¬λͺ
μ μ΄λ€. κ²°λ‘ μ μΌλ‘ DecoratorPatternμ μ¬κ·μ μΈ compositionμ μ κ³΅νλ€. μ΄κ²μ μμν adapterλ‘μλ λΆκ°λ₯νλ€. 
ProxyPatternμ ν΄λΉ κ°μ²΄μ λν λ리μ μν μ νλ©°, μ€μ  κ°μ²΄μ λν interfaceλ₯Ό λ³νμν€μ§ μλλ€.




















