Паттерны проектирования

Содержание

Слайд 2

Что такое паттерны (шаблоны) проектирования?

Эффективные способы решения характерных задач проектирования
Обобщенное описание решения

Что такое паттерны (шаблоны) проектирования? Эффективные способы решения характерных задач проектирования Обобщенное
задачи, которое можно использовать в различных ситуациях
ОО паттерны проектирования часто показывают отношения и взаимодействия между классами и объектами
Алгоритмы не являются паттернами, т.к. решают задачу вычисления, а не программирования

Слайд 3

Польза

Каждый паттерн описывает решение целого класса проблем
Каждый паттерн имеет известное имя
облегчается взаимодействие

Польза Каждый паттерн описывает решение целого класса проблем Каждый паттерн имеет известное
между разработчиками
Правильно сформулированный паттерн проектирования позволяет, отыскав удачное решение, пользоваться им снова и снова
Шаблоны проектирования не зависят от языка программирования, в отличие от идиом

Слайд 4

Порождающие паттерны

Порождающие паттерны

Слайд 5

Порождающие паттерны проектирования

Абстрагируют процесс инстанцирования объектов
Список паттернов
Абстрактная фабрика (Abstract Factory)
Строитель (Builder)
Фабричный метод

Порождающие паттерны проектирования Абстрагируют процесс инстанцирования объектов Список паттернов Абстрактная фабрика (Abstract
(Factory method)
Прототип (Prototype)
Одиночка (Singleton)

Слайд 6

Abstract Factory (Абстрактная фабрика)

Abstract Factory (Абстрактная фабрика)

Слайд 7

Назначение паттерна «Абстрактная фабрика»

Предоставляет интерфейс для создания семейств взаимосвязанных или взаимозависимых объектов,

Назначение паттерна «Абстрактная фабрика» Предоставляет интерфейс для создания семейств взаимосвязанных или взаимозависимых
не специфицируя их конкретных классов

Слайд 8

Паттерн «Абстрактная фабрика»

Шаблон проектирования, позволяющий изменять поведение системы, варьируя создаваемые объекты, при

Паттерн «Абстрактная фабрика» Шаблон проектирования, позволяющий изменять поведение системы, варьируя создаваемые объекты,
этом сохраняя интерфейсы
Предоставляет интерфейс для создания семейств взаимосвязанных или взаимозависимых объектов, не специфицируя их конкретных классов

Слайд 9

Реализация паттерна

Паттерн «Абстрактная фабрика» реализуется созданием абстрактного класса Factory, который представляет собой

Реализация паттерна Паттерн «Абстрактная фабрика» реализуется созданием абстрактного класса Factory, который представляет
интерфейс для создания абстрактных объектов-продуктов
На основе данного класса создается один или несколько классов конкретных фабрик, создающих конкретные объекты-продукты

Слайд 10

Применение паттерна

Используйте паттерн, когда
Система не должна зависеть от того, как создаются, компонуются

Применение паттерна Используйте паттерн, когда Система не должна зависеть от того, как
и представляются входящие в нее объекты
Входящие в семейство взаимосвязанные объекты должны использоваться вместе и вам необходимо обеспечить выполнение этого ограничения
Система должна конфигурироваться одним из семейств составляющих ее объектов
Требуется предоставить библиотеку объектов, раскрывая только их интерфейсы, но не реализацию.

Слайд 11

Структура

Объявляет интерфейс для операций, создающих абстрактные объекты-продукты

Реализует операции, создающие конкретные объекты-продукты;

Объявляет интерфейс

Структура Объявляет интерфейс для операций, создающих абстрактные объекты-продукты Реализует операции, создающие конкретные
для типа объекта-продукта

Определяет объект-продукт, создаваемый соответствующей конкретной фабрикой

Пользуется исключительно интерфейсами, которые объявлены в классах AbstractFactory и AbstractProduct

Слайд 12

Пример использования

При разработке приложений с графическим интерфейсом пользователя необходимо создавать различные элементы

Пример использования При разработке приложений с графическим интерфейсом пользователя необходимо создавать различные
управления
Кнопки, текстовые поля, радио-кнопки, выпадающие списки и т.п.
Их создание и работа с ними в различных ОС осуществляется по-разному
Чтобы приложение можно было легче перенести в другую ОС в нем не должно быть жесткой привязки к типам конкретных классов элементов управления
Паттерн «Абстрактная фабрика» облегчает решение данной задачи

Слайд 13

Иерархия классов

CButton

CWindowsButton

CMacOSXButton

CRadioButton

CWindowsRadioButton

CMacOSXRadioButton

CCheckBox

CWindowsCheckBox

CMacOSXCheckBox

Иерархия классов CButton CWindowsButton CMacOSXButton CRadioButton CWindowsRadioButton CMacOSXRadioButton CCheckBox CWindowsCheckBox CMacOSXCheckBox

Слайд 14

Абстрактные и конкретные элементы управления

class CButton
{
public:
virtual ~CButton(){}
//...
};
class CWindowsButton : public CButton
{
//...
};
class CMacOSXButton

Абстрактные и конкретные элементы управления class CButton { public: virtual ~CButton(){} //...
: public CButton
{
//...
};

class CCheckBox
{
public:
virtual ~CCheckBox(){}
// ...
};
class CWindowsCheckBox : public CCheckBox
{
// ...
};
class CMacOSXCheckBox : public CCheckBox
{
// ...
};

Слайд 15

Абстрактная и конкретные фабрики

class CUIFactory
{
public:
virtual CButton* CreateButton()const=0;
virtual CCheckBox* CreateCheckBox()const=0;
};
class CWindowsUIFactory : public

Абстрактная и конкретные фабрики class CUIFactory { public: virtual CButton* CreateButton()const=0; virtual
CUIFactory
{
public:
virtual CButton* CreateButton()const
{
return new CWindowsButton();
}
virtual CCheckBox* CreateCheckCBox()const
{
return new CWindowsCheckBox();
}
};

class CMacOSXUIFactory : public CUIFactory
{
public:
virtual CButton* CreateButton()const
{
return new CMacOSXButton();
}
virtual CCheckBox* CreateCheckBox()const
{
return new CMacOSXCheckBox();
}
};

void BuildUI(CUIFactory const& uiFactory)
{
CButton * pOKButton = uiFactory.CreateButton();
CCheckBox * pCheckBox= uiFactory.CreateCheckBox();
}
int main(int argc, char* argv[])
{
CWindowsUIFactory uiFactory;
BuildUI(uiFactory);
return 0;
}

Слайд 16

Преимущества использования паттерна «Абстрактная фабрика»

Изоляция конкретных классов продуктов
Фабрика изолирует клиента от деталей

Преимущества использования паттерна «Абстрактная фабрика» Изоляция конкретных классов продуктов Фабрика изолирует клиента
реализации классов продуктов
Имена изготавливаемых классов известны только конкретной фабрике, в коде клиента они не упоминаются
Клиенты манипулируют экземплярами продуктов только через их абстрактные интерфейсы
Упрощение замены семейств продуктов
Приложение может изменить семейство продуктов просто подставив новую конкретную фабрику
Гарантия сочетаемости продуктов
Если продукты спроектированы для совместного использования, важно чтобы в каждый момент времени приложение работало с продуктами единственного семейста

Слайд 17

Недостатки паттерна «Абстрактная фабрика»

Трудность поддержания новых типов продуктов
Интерфейс абстрактной фабрики фиксирует набор

Недостатки паттерна «Абстрактная фабрика» Трудность поддержания новых типов продуктов Интерфейс абстрактной фабрики
продуктов, которые можно создать
Для поддержки новых продуктов необходимо расширить интерфейс фабрики, внеся изменения в класс AbstractFactory, а также во все его подклассы
Обход этого ограничения – передача идентификатора типа создаваемого продукта в методы фабрики, создающие продукты
Ограничение: создаваемые продукты должны поддерживать общий абстрактный интерфейс
Клиент не может различать типы продуктов и делать какие-либо предположения о них

Слайд 18

Пример – фабрика, создающая элементы игрового поля

enum ItemType
{
WALL,
WATER,
FOREST,
SAND,
};
class IMapItem
{
public:
virtual ~IMapItem(){}
// ...
};
class CWall

Пример – фабрика, создающая элементы игрового поля enum ItemType { WALL, WATER,
: public IMapItem {};
class CWater : public IMapItem {};
class CForest : public IMapItem {};
class CSand : public IMapItem {};

class CMapItemsFactory
{
public:
IMapItem* CreateItem(ItemType type)const
{
switch (type)
{
case WALL: return new CWall();
case WATER: return new CWall();
case FOREST: return new CForest();
case SAND: return new CSand();
default:
throw new std::invalid_argument
("Unknown item type");
}
}
};

Слайд 19

Builder (Строитель)

Builder (Строитель)

Слайд 20

Назначение паттерна «Строитель»

Отделяет конструирование сложного объекта от его представления, так что в

Назначение паттерна «Строитель» Отделяет конструирование сложного объекта от его представления, так что
результате одного и того же процесса конструирования могут получаться разные представления

Слайд 21

Область применения паттерна «Строитель»

Алгоритм создания сложного объекта не должен зависеть от того,

Область применения паттерна «Строитель» Алгоритм создания сложного объекта не должен зависеть от
из каких частей состоит объект и как они стыкуются между собой
Процесс конструирования должен обеспечивать различные представления конструируемого объекта

Слайд 22

Структура

Задает абстрактный интерфейс для частей объекта Product

Реализует интерфейс Builder, конструирует и собирает

Структура Задает абстрактный интерфейс для частей объекта Product Реализует интерфейс Builder, конструирует
вместе части продукта
Определяет создаваемое представление продукта и следит за ним
Предоставляет интерфейс для доступа к продукту

Конструирует продукт при помощи интерфейса Builder

Представляет сложный конструируемый объект
Включает классы, которые определяют составные части и интерфейсы для сборки конечного результата из частей

Слайд 23

Отношения между участниками паттерна

Клиент создает новый объект «Распорядитель» (Director) и конфигурирует его

Отношения между участниками паттерна Клиент создает новый объект «Распорядитель» (Director) и конфигурирует
новым объектом-строителем Builder
Распорядитель уведомляет строителя о необходимости построения очередной части продукта
Строитель обрабатывает запросы распорядителя и добавляет новые части к продукту
Клиент забирает продукт у строителя

Слайд 24

Достоинства паттерна «Строитель»

Позволяет изменять внутреннее представление продукта
Распорядителю предоставляется абстрактный интерфейс Строителя, скрывающего

Достоинства паттерна «Строитель» Позволяет изменять внутреннее представление продукта Распорядителю предоставляется абстрактный интерфейс
структуру продукта и процесс сборки
Для изменения внутреннего представления достаточно определить новую реализацию Строителя
Изолирует код, реализующий конструирование и представление
Клиенту не нужно знать о классах, задающих внутреннюю структуру продукта (в интерфейсе строителя они отсутствуют)
Дает более тонкий контроль над процессом конструирования
Процесс построения продукта происходит не сразу, как в других порождающих паттернах, а шаг за шагом

Слайд 25

Пример использования

В редакторе форматированного текстового документа необходимо реализовать возможность преобразования его в

Пример использования В редакторе форматированного текстового документа необходимо реализовать возможность преобразования его
различные форматы
Plain text, HTML, RTF, PDF, DOC, DOCX
Список можно продолжить
Задача решается путем введения сущностей
Распорядитель - CFormattedTextReader
Строитель – CTextConverter
Конкретный Строитель – CHtmlConverter, CRTFConverter, CPlainTextConverter, CPDFConverter, …
Продукт – CPlainTextDocument, CHtmlDocument, CRTFDocument, CPDFDocument, …

Слайд 26

Иерархия классов

Распорядитель

Продукты

Строитель

Иерархия классов Распорядитель Продукты Строитель

Слайд 27

Реализация сущности «Строитель»

class CTextConverter
{
public:
virtual void ConvertText
(std::string const& s){}
virtual void ConvertFontChange
(CFont const& fnt){}
//

Реализация сущности «Строитель» class CTextConverter { public: virtual void ConvertText (std::string const&

};
class CPlainTextConverter
: public CTextConverter
{
public:
void ConvertText(std::string const& s)
{
// …
}
std::string const & GetPlainText()const
{
return m_plainText;
}
private:
std::string m_plainText;
};

class CPDFConverter
: public CTextConverter
{
public:
void ConvertText(std::string const& w)
{
// ...
}
void ConvertFontChange(CFont const& fnt)
{
// ...
}
CPDFDocument const& GetPDFDocument() const
{
return m_pdfDocument;
}
private:
CPDFDocument m_pdfDocument;
};

Слайд 28

Реализация сущности «Распорядитель»

class CFormattedTextReader
{
public:
void Read(CFormattedText const& text, CTextConverter & converter)
{
for (size_t index

Реализация сущности «Распорядитель» class CFormattedTextReader { public: void Read(CFormattedText const& text, CTextConverter
= 0; index < text.GetItems(); ++index)
{
CTextItem const & item = text.GetItem(index);
CTextRangeItem const* pTextRange = NULL;
CFontChangeCommand const& * pFontCommand = NULL;
if (pTextRange = dynamic_cast(&item))
{
converter.ConvertText(pTextRange->GetText());
}
else if (pFontCommand = dynamic_cast(&item))
{
converter.ConvertFontChange(pFontCommand->GetFont());
}
else if (…) { … } …
}
}
};

Слайд 29

Реализация клиента

void ConvertToPDF(CFormattedText const& text, std::string const& outputFile)
{
// создаем строителя
CPDFConverter converter;
// создаем

Реализация клиента void ConvertToPDF(CFormattedText const& text, std::string const& outputFile) { // создаем
распорядителя
CFormattedTextReader reader;
// и инициируем процесс построения продукта
reader.Read(text, converter);
// получаем конечный продукт
CPDFDocument const& pdfDoc = converter.GetPDFDocument();
pdfDoc.SaveToFile(outputFile);
}

Слайд 30

Factory Method (Фабричный метод)

Factory Method (Фабричный метод)

Слайд 31

Назначение паттерна «Фабричный метод»

Определяет интерфейс для создания объекта, но оставляет подклассам решение

Назначение паттерна «Фабричный метод» Определяет интерфейс для создания объекта, но оставляет подклассам
о том, какой класс инстанцировать
Фабричный метод позволяет классу делегировать инстанцирование подклассам
Альтернативное название паттерна – «Виртуальный конструктор»

Слайд 32

Структура

Определяет интерфейс объектов, создаваемых фабричным методом

Реализует интерфейс Product

Объявляет фабричный метод, возвращающий объект

Структура Определяет интерфейс объектов, создаваемых фабричным методом Реализует интерфейс Product Объявляет фабричный
типа Product, может также определять реализацию по умолчанию данного фабричного метода
Может вызывать фабричный метод для создания объекта Product.

Замещает фабричный метод, возвращающий объект ConcreteProduct

Слайд 33

Отношения между участниками паттерна

Создатель «полагается» на свои подклассы в определении фабричного метода,

Отношения между участниками паттерна Создатель «полагается» на свои подклассы в определении фабричного
который будет возвращать экземпляр подходящего конкретного продукта

Слайд 34

Применимость

Классу заранее неизвестно, объекты каких классов ему нужно создавать
Класс спроектирован так, чтобы

Применимость Классу заранее неизвестно, объекты каких классов ему нужно создавать Класс спроектирован
объекты, которые он создает, специфицировались подклассами
Класс делегирует свои обязанности одному из нескольких вспомогательных подклассов
тип конкретного вспомогательного подкласса выбирается в ходе выполнения программы

Слайд 35

Пример использования

Каркас приложения, позволяющего пользователю работать с различными типами документов
Основные абстракции в

Пример использования Каркас приложения, позволяющего пользователю работать с различными типами документов Основные
таком каркасе – классы CApplication и CDocument
CApplication – управляет созданием и открытием документов
CDocument – базовый абстрактный класс CDocument, основа для создания конкретных документов
Проблема – класс CApplication знает, в какой момент документ должен быть создан, но ему известно лишь об абстрактном классе CDocument, который инстанцировать нельзя
Паттерн «Фабричный метод» предлагает решение данной проблемы

Слайд 36

Иерархия классов

Иерархия классов

Слайд 37

Абстрактные реализации сущностей «Product» и «Creator»

// Абстрактный Продукт
class CDocument
{
public:
virtual ~CDocument(){}
virtual void Open()=0;
virtual

Абстрактные реализации сущностей «Product» и «Creator» // Абстрактный Продукт class CDocument {
void Save()=0;
virtual void Close()=0;
};
typedef boost::shared_ptr CDocumentPtr;

// Абстракный Создатель
class CApplication
{
public:
~ CApplication(){}
void NewDocument()
{
CDocumentPtr pDocument(CreateDocument());
m_docs.push_back(pDocument);
}
void OpenDocument()
{
CDocumentPtr pDocument(CreateDocument());
m_docs.push_back(pDocument);
pDocument->Open();
}
protected:
// фабричный метод
virtual CDocument * CreateDocument()const = 0;
private:
std::vector m_docs;
};

Слайд 38

Конкретные реализации сущностей «Product» и «Creator»

// конкретный продукт
class CMyDocument : public CDocument
{
public:
virtual

Конкретные реализации сущностей «Product» и «Creator» // конкретный продукт class CMyDocument :
void Open()
{
// ...
}
virtual void Close()
{
// ...
}
virtual void Save()
{
// ...
}
};

// Конкретный создатель
class CMyApplication : public CApplication
{
protected:
// реализация фабричного метода
virtual CDocument * CreateDocument()const
{
return new CMyDocument();
}
};

Имя файла: Паттерны-проектирования.pptx
Количество просмотров: 201
Количество скачиваний: 0