Wzorzec projektowy adapter

Stronę tą wyświetlono już: 13 razy

Opis wzorca projektowego adapter

Wzorzec projektowy adapter należy do strukturalnych wzorców projektowych i umożliwia on zaimplementowanie tego samego interfejsu w klasach, które nie są kompatybilne. Taka sytuacja może mieć miejsce, gdy korzysta się z klas znajdujących się w bibliotekach dll, gdzie nie ma możliwości ich modyfikacji lub w sytuacji, gdy takie dostosowanie było by zbyt czasochłonne.

Przykład diagramu UML dla wzorca projektowego adapter

Dla przykładu utwórzmy sobie klasę Point2d, która dziedziczy tylko po interfejsie iPoint2d. Należy zastosować wzorzec projektowy adapter jako klasę Vector3d, który dziedziczyć będzie klasę Point2d oraz interfejs iPoint3d. Z tego interfejsu będzie korzystał użytkownik (czyli dalsza część kodu nie związana już z samym wzorcem projektowym adapter).

Przykładowy diagram UML wzorca projektowego adapter
Rys. 1
Przykładowy diagram UML wzorca projektowego adapter

Przykładowa implementacja wzorca projektowego adapter

Listing 1
  1. #include <iostream>
  2. class iPoint2d{
  3. public:
  4. virtual void writePoint() const = 0;
  5. virtual double getX() const = 0;
  6. virtual double getY() const = 0;
  7. };
  8. class Point2d : public iPoint2d{
  9. protected:
  10. double x;
  11. double y;
  12. public:
  13. Point2d(double x, double y) : x(x), y(y){}
  14. virtual void writePoint() const {
  15. std::cout<<"Punkt 2W: {"<<x<<", "<<y<<"}"<<std::endl;
  16. }
  17. inline virtual double getX() const{
  18. return x;
  19. }
  20. inline virtual double getY() const{
  21. return y;
  22. }
  23. };
  24. class iPoint3d{
  25. public:
  26. virtual double getZ() const = 0;
  27. virtual void writePoint() const = 0;
  28. virtual double getX() const = 0;
  29. virtual double getY() const = 0;
  30. };
  31. class Vector3d : public iPoint3d, private Point2d{
  32. public:
  33. Vector3d(const iPoint2d* p2d) : Point2d(p2d->getX(), p2d->getY()){
  34. std::cout<<"Create adapter"<<std::endl<<std::endl;
  35. }
  36. virtual void writePoint() const{
  37. std::cout<<"Punkt 3W: {"<<x<<", "<<y<<", 0}"<<std::endl;
  38. }
  39. inline virtual double getZ() const{
  40. return 0;
  41. }
  42. inline virtual double getX() const{
  43. return x;
  44. }
  45. inline virtual double getY() const{
  46. return y;
  47. }
  48. };
  49. int main(){
  50. iPoint2d* p2d = new Point2d(100,100);
  51. p2d->writePoint();
  52. std::cout<<std::endl;
  53. iPoint3d* p3d = new Vector3d(p2d);
  54. p3d->writePoint();
  55. if(p3d){
  56. delete p3d;
  57. p3d = NULL;
  58. }
  59. if(p2d){
  60. delete p2d;
  61. p2d = NULL;
  62. }
  63. std::cin.get();
  64. return 0;
  65. }

Wynik działania programu:

Punkt 2W: {100, 100}

Create adapter

Punkt 3W: {100, 100, 0}
Strony powiązane
strony powiązane
  1. sourcemaking.com/design_patterns/adapter - strona opisująca wzorzec projektowy adapter [En]
  2. pl.wikipedia.org - opis tego wzorca na stronie Wikipedii

Komentarze