Evgenii Legotckoi
Evgenii LegotckoiҚыр. 21, 2018, 5:11 Т.Қ.

Құрылымдық дизайн үлгілері - адаптер

Цели

  1. Преобразование интерфейса класса в другой интерфейс. Адаптер позволяет классам работать вместе, что в противном случае могло бы быть связано с несовместимыми интерфейсами классов.
  2. Оборачивание существующего класса в новый интерфейс
  3. Соответствие старого компонента новой системе

Проблематика

Уже готовый компонент имеет всё необходимое для разработки вашей системы, но его интерфейсы несовместимы с интерфейсами классов вашего приложения.


Обсуждение

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

Это похоже на проблему вставки нового трехштырькового электрического штепселя в старую двухштырьковую розетку - необходим какой-то адаптер или посредник.

Адаптер - это создание промежуточной абстракции, которая переводит или сопоставляет старый компонент в новую систему. Клиенты вызывают методы объекта Adapter, которые перенаправляют их на вызовы унаследованного компонента. Эта стратегия может быть реализована либо с наследованием, либо с агрегацией.

Адаптер функционирует как оболочка или модификатор существующего класса. Он предоставляет другое или переведенное представление этого класса.

Структура

Ниже, устаревший метод display() для компонента Rectangle, используемый в Rectangle, рассчитывает получить параметры «x, y, w, h». Но клиент хочет передать «верхние левые x и y» и «нижние правые x и y». Эта несогласованность может быть исправлена путем добавления дополнительного уровня абстракции - т. е. объекта адаптера.

Адаптер также можно рассматривать как «обертку».

Пример

Шаблон адаптера позволяет другим несовместимым классам работать вместе, преобразовывая интерфейс одного класса в интерфейс, ожидаемый клиентами. Сокеты с гнездами служат примером адаптера. Розетка прикрепляется к храповику, при условии, что размер привода одинаковый. Типичные размеры дисков в США составляют 1/2 "и 1/4". Очевидно, что храповой механизм 1/2 "не будет входить в гнездо 1/4", если адаптер не используется. Адаптер с диагональю от 1/2 дюйма до 1/4 "имеет 1/2" гнездовое соединение для крепления на шейкер 1/2 "и 1/4" штыревое соединение для установки в гнездо 1/4 ".

Контрольный список

  1. Определите игроков: компонент (ы), которые хотите использовать (то есть клиент), и компонент, который необходимо адаптировать (например, адаптируемый).
  2. Определите интерфейс, который требуется клиенту.
  3. Создайте класс «обертка», который может «соответствовать интерфейсу» клиента.
  4. Класс адаптера/обертки «имеет» экземпляр адаптируемого класса.
  5. Класс адаптера/обертки «сопоставляет» интерфейс клиента с адаптированным интерфейсом.
  6. Клиент использует новый интерфейс

Эмпирические правила

  • Адаптер позволяет работать классам после того, как они разработаны; Мост заставляет их работать до того, как они будут разработаны.
  • Мост разработан заранее, чтобы абстракция и реализация менялись независимо. Адаптер модернизирует, чтобы совместные классы работали вместе.
  • Адаптер предоставляет другой интерфейс для своего объекта. Прокси обеспечивает тот же интерфейс. Декоратор обеспечивает расширенный интерфейс.
  • Адаптер предназначен для изменения интерфейса существующего объекта. Декоратор улучшает работу другого объекта без изменения его интерфейса. Декоратор, таким образом, более прозрачен для приложения, чем адаптер. Как следствие, Декоратор поддерживает рекурсивную композицию, что невозможно при использовании чистых адаптеров.
  • Фасад определяет новый интерфейс, тогда как Adapter использует старый интерфейс. Помните, что адаптер поддерживает два существующих интерфейса, а не определяет совершенно новый.
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

Пікірлер

Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
Кіріңіз немесе Тіркеліңіз
Ua

Qt - Тест 001. Сигналы и слоты

  • Нәтиже:84ұпай,
  • Бағалау ұпайлары4
Ua

Qt - Тест 001. Сигналы и слоты

  • Нәтиже:42ұпай,
  • Бағалау ұпайлары-8
ОК

Qt - Тест 001. Сигналы и слоты

  • Нәтиже:47ұпай,
  • Бағалау ұпайлары-6
Соңғы пікірлер
ИМ
Игорь МаксимовҚар. 22, 2024, 9:51 Т.Қ.
Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii LegotckoiҚаз. 31, 2024, 11:37 Т.Қ.
Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZEҚаз. 19, 2024, 5:19 Т.Қ.
Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь МаксимовҚаз. 5, 2024, 4:51 Т.Қ.
Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas5Шілде 5, 2024, 8:02 Т.Қ.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Енді форумда талқылаңыз
f
firstlunoxodАқп. 15, 2025, 1:46 Т.Қ.
Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
Дмитрий
ДмитрийАқп. 3, 2025, 4:24 Т.Қ.
Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
NW
Nayo WaiҚаң. 30, 2025, 7:22 Т.Қ.
не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
n
nklyҚаң. 3, 2025, 12:52 Т.Қ.
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
MarselТам. 17, 2023, 12:26 Т.Ж.
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

Бізді әлеуметтік желілерде бақылаңыз