ru:https://highload.today/blogs/strategy-pattern/ ua:https://highload.today/uk/blogs/strategy-pattern/
logo
Основы      19/01/2022

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

Николай Коваленко BLOG

Backend Developer в Ronis Business Tools

Как пишут в Википедии, стратегия — это поведенческий шаблон проектирования, предназначенный для определения семейства алгоритмов, инкапсуляции каждого из них и обеспечения их взаимозаменяемости.

Вот так выглядит стратегия в UMLангл. Unified Modeling Language — унифицированный язык моделирования:

Непонятно ровным счетом ничего, скажут многие и будут правы.

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

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

Что представляет собой паттерн «Стратегия»

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

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

Таким образом выполняется правило единой ответственности класса (объект отвечает за набор данных, а реализация поведения — за то, как эти данные себя ведут), что очень хорошо сказывается на размере классов, количестве зависимостей, дублировании кода и дальнейшей поддержке проекта.

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

Онлайн-курс "Маркетингова аналітика" від Laba.
Опануйте інструменти для дослідження ринку й аудиторії та проведення тестувань.Дізнайтесь, як оптимізувати поточні рекламні кампанії та будувати форкасти наступних.
Детальніше про курс

Зачем нужен паттерн «Стратегия»

Все это, конечно, хорошо, но зачем все это нужно? Ведь такая реализация приводит к тому, что мы усложняем статический анализ кода, пряча конкретную реализацию поведения за интерфейсом и используемым механизмом внедрения зависимостей.

Реализация паттерна «Стратегия» позволяет более гибко использовать полиморфизм поведения объекта без необходимости дублирования кода и наращивания уровней иерархии наследования.

inheritage

Чем стратегия лучше переопределения методов в наследниках?

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

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

Реализация паттерна «Стратегия» лишена этого недостатка. Всегда можно применить любой набор существующих поведений и расширять его до бесконечности без необходимости каких-либо изменений структуры приложения.

strategy-realization

Когда применять паттерн «Стратегия»

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

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

Онлайн-курс "Режисура та візуальний сторітелінг" від Skvot.
Перетворюй свої ідеї на сильні історії в рекламі, кліпах чи кіно Досвідом ділиться режисер, продюсер та власник продакшену, який 10+ років у професії.
Детальніше про курс

Такой подход не требует больших усилий и существенных архитектурных изменений проекта.

Программная реализация паттерна «Стратегия»

Реализацию на PHP приводить не буду, так как она довольно простая, если понять суть применения паттерна на практике. Проблему может вызвать только необходимость иметь что-то вроде фабрики или фабричного метода для создания нужной реализации конкретного поведения объекта. Но это можно легко сделать при помощи механизма внедрения зависимостей (dependency injection), без которого не обходится ни один проект.

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

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

Спасибо, что дочитали до конца. Надеюсь, информация была полезна.

Читайте также: Принцип SOLID, который все понимают неправильно: что такое единая ответственность в разработке

Это текст из личного блога, опубликованный с разрешения автора.

Онлайн-курс "Чистий код та патерни проєктування" від robot_dreams.
Прискорюйте й спрощуйте процес розробки.Під менторством лектора з 15-річним досвідом ви навчитеся застосовувати 20+ шаблонів, опануєте рефакторинг і принципи чистого коду.
Детальніше

If you have found a spelling error, please, notify us by selecting that text and pressing Ctrl+Enter.

Онлайн-курс "Project Manager" від Laba.
Станьте проджектом, що вміє передбачати ризики наперед і доводити проєкт до результату, який хочуть замовники. Поділиться досвідом Павло Харіков, former Head of PMO в Kyivstar.
Програма курсу і реєстрація

Этот материал – не редакционный, это – личное мнение его автора. Редакция может не разделять это мнение.

Топ-5 самых популярных блогеров марта

PHP Developer в ScrumLaunch
Всего просмотровВсего просмотров
2434
#1
Всего просмотровВсего просмотров
2434
Founder at Shallwe, Python Software Engineer (Django/React)
Всего просмотровВсего просмотров
113
#2
Всего просмотровВсего просмотров
113
Career Consultant в GoIT
Всего просмотровВсего просмотров
95
#3
Всего просмотровВсего просмотров
95
CEO & Founder в Trustee
Всего просмотровВсего просмотров
94
#4
Всего просмотровВсего просмотров
94
Рейтинг блогеров

Ваша жалоба отправлена модератору

Сообщить об опечатке

Текст, который будет отправлен нашим редакторам: