Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
!Шпора по ООПиП (3).docx
Скачиваний:
35
Добавлен:
22.09.2019
Размер:
2.31 Mб
Скачать

78. Одиночка (шаблон проектирования)

порождающий шаблон проектирования.

Цель

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

Плюсы

  • контролируемый доступ к единственному экземпляру;

  • уменьшение числа имён;

  • допускает уточнение операций и представления;

  • допускает переменное число экземпляров;

  • бо́льшая гибкость, чем у операций класса.

Минусы

  • Глобальные объекты могут быть вредны для объектного программирования, в некоторых случаях приводя к созданию немасштабируемого проекта.

Применение

  • должен быть ровно один экземпляр некоторого класса, легко доступный всем клиентам;

  • единственный экземпляр должен расширяться путем порождения подклассов, и клиентам нужно иметь возможность работать с расширенным экземпляром без модификации своего кода.

using System;

public class Singleton

{

private static Singleton instance;

private Singleton() {}

public static Singleton Instance

{

get

{

if (instance == null)

{

instance = new Singleton();

}

return instance;

}

}

}

79. Структурные шаблоны

шаблоны проектирования, в которых рассматривается вопрос о том, как из классов и объектов образуются более крупные структуры.

Использование

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

Шаблоны

  • Адаптер

  • Мост

  • Компоновщик

  • Декоратор

  • Фасад

  • Front Controller 

  • Приспособленец

  • Заместитель

80. Адаптер (шаблон проектирования)

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

Задача

Система поддерживает требуемые данные и поведение, но имеет неподходящий интерфейс. Чаще всего шаблон Адаптер применяется, если необходимо создать класс, производный от вновь определяемого или уже существующего абстрактного класса.

Способ решения

Адаптер предусматривает создание класса-оболочки[1] с требуемым интерфейсом.

Участники

Класс Adapter приводит интерфейс класса Adaptee в соответствие с интерфейсом класса Target (наследником которого является Adapter). Это позволяет объекту Client использовать объект Adapter так, словно он является экземпляром класса Target.

Следствия

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

Реализация

Включение уже существующего класса в другой класс. Интерфейс включающего класса приводится в соответствие с новыми требованиями, а вызовы его методов преобразуются в вызовы методов включённого класса.

// Target

public interface Chief

{

public Object makeBreakfast();

public Object makeLunch();

public Object makeDinner();

}

// Adaptee

public class Plumber

{

public Object getScrewNut()

{ ... }

public Object getPipe()

{ ... }

public Object getGasket()

{ ... }

}

// Adapter

public class ChiefAdapter extends Plumber implements Chief

{

public Object makeBreakfast()

{

return getGasket();

}

public Object makeLunch()

{

return getPipe();

}

public Object makeDinner()

{

return getScrewNut();

}

}

// Client

public class Client

{

public static void eat(Object dish)

{ ... }

public static void main(String[] args)

{

Chief ch = new ChiefAdapter();

Object dish = ch.makeBreakfast();

eat(dish);

dish = ch.makeLunch();

eat(dish);

dish = ch.makeDinner();

eat(dish);

callAmbulance();

}

}