;
Сергей Тепляков

Принцип YAGNI

25.08.2016 5863
IBS Training Center Telegram
Подписывайтесь на наш канал в Telegram:
больше материалов экспертов, анонсы бесплатных вебинаров и задачки для IT-специалистов
Подписаться
На ru.stackoverflow.com недавно был задан вопрос, который ИМХО стоит вашего внимания: Нарушает ли OCP и DIP (из SOLID) принцип YAGNI?. Ниже представлен немного более развернутая версия моего ответа.

Разные принципы проектирования направлены на решение противоречащих друг другу задач проектирования. Можно сказать, что разные принципы «тянут» дизайн в разные стороны и нужно найти правильный вектор, наиболее полезный в данном конкретном случае. SRP толкает в стороны простого решения, а OCP – в сторону изоляции компонентов, а DIP – направлен на построение правильных отношений между типами.

Следование одному принципу может привести к нарушению другого. Так, например, любое наследование *можно* рассматривать как нарушение SPR, поскольку теперь за одну ответственность (рисование фигур) отвечает целая группа классов. Принципы DIP и OCP, которые часто требуют наследования, могут привести к появлению дополнительных «швов», т.е. интерфейсов/базовых классов в системе, что, опять-таки, приведет к нарушению SRP и/или ISP.

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

Принцип YAGNI (You Aren’t Gonna Need It) – это более фундаментальный принцип («принцип высшего порядка» или «метапринцип»), который поможет понять, когда следовать принципам/паттернам/правилам, а когда нет.

В основе принципа YAGNI лежит несколько наблюдений:

1. Программисты, как и люди в целом, плохо предсказывают будущее.

2. Затраты, сделанные сейчас могут быть оправданными или неоправданными в будущем.

3. Ни одно гибкое решение не будет достаточно гибким.

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

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

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

Проще всего добиться этого путем эволюционного дизайна: мы начинаем с разбиения системы на крупные компоненты, но не занимаемся выделением лишних уровней абстракции. Не нужны базовые классы, если сейчас нет хотя бы 2-х-3-х наследников. И даже если такие наследники «могут появиться в будущем», то выделить иерархию типов нужно именно тогда, когда это самое будущее настанет.

Существует простая лакмусовая бумажка принципа YAGNI: выделение лишних абстракций (и любое другое усложнение) оправдано лишь в том случае, если стоимость их выделения в будущем будет существенно дороже, чем сейчас.

Инвестиции в продуманность интерфейса программирования библиотеки (API) – будут оправданны, поскольку стоимость внесения изменений очень высока. Стоимость же выделения интерфейса/базового класса в приложении является практически одинаковой сегодня или через год. Но через год данное выделение будет более оправданным экономически и практически. Мы не делали лишнюю работу раньше времени, а значит можем сосредоточить усилия на чем-то важным в данный момент. К тому же, через год у нас появится больше информации на предмет того, каким именно должен быть базовый класс или интерфейс, поскольку они будут основаны на реальных, а не воображаемых требованиях.

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

Расскажи друзьям:

Walker
Pandora Jewelry Charms
Jordans 1
Cheap Jordan Shoes
Nike Sneakers For Women
Air Jordan 1 High
Pandora Jewelry Official Site
Pandora Jewelry
Pandora Bracelets Charms
Nike Air Max 720
Moncler Coat
Nike Sneakers For Men
Jordan 1 Retro
Pandora Canada
Moncler Outlet
Moncler Jacket
Pandora Official Site
Nike Shoes
Asics Sneakers
Jordan Retro 5
Pandora Black Friday
Nike Canada
Balenciaga Sneakers
Ferragamo Belt
Moncler Jacket
Nike Air Max 270
Pandora Charms
Cheap Moncler
Nike Shoes Women
Pandora Jewellery
Pandora Charms
Pandora Rings
Balenciaga
Pandora Website
Cheap Mens Adidas Shoes
Balenciaga
Moncler Sale
Pandora
Nike Outlet Store Online Shopping
Air Jordan 1 Dior
Air Jordan 1 Low
Pandora
Ferragamo Shoes
Balenciaga Sneakers
Jordan Wholesale Distributors
Nike Store
Air Jordan 1s
Pandora Outlet
Pandora Jewelry
Pandora
Asics Shoes
Pandora Charm Bracelet
Nike UK
Adidas Sneakers
Pandora Outlet
Nike Mens Shoes
Adidas Running Shoes
Salvatore Ferragamo Belt
Nike Air Max
Asics Kayano
Pandora Jewelry
Pandora Bracelet Charms
Pandora Charms Outlet
Pandora Jewelry
Pandora Bracelets
Air Jordan 1
Pandora Rings
Basketball Shoes
Air Jordan Shoes
Adidas Canada
Nike Outlet Store Online Shopping
Asics Shoes
Nike Canada
Pandora Jewelry
Air Jordan Shoes
Balenciaga Triple S Sneakers
Nike Outlet
Ferragamo Shoes
Pandora Charms
Yeezy Shoes
Pandora
Pandora Outlet Online
Air Max 97
Pandora Jewelry Official Site
Nike Shoes For Men
Pandora
Balenciaga Sneakers
Moncler Jackets Outlet
Pandora Charms Outlet
Pandora Jewelry Official Site
Jewelry Pandora
Adidas Shoes Women
Goyard Bags
Moncler Coats
Pandora Charms Sale Clearance
Nike Running Shoes
Pandora
Nike Shoes
Pandora Jewellery
Pandora Bracelets
Nike
Pandora Charms
Air Jordan 1 Retro
Pandora Jewelry Outlet
Adidas Shoes Men
Moncler Jackets Outlet
Pandora
Adidas Clearance Sale
Pandora
Puma Shoes
Pandora Charms
Pandora Bracelets
Jordan Sneakers
Asics Outlet
Pandora Official Site
Yeezy Shoes
Adidas Canada
Jordan One
Jordan 1 Low
Asics Running Shoes For Women
Nike Air Jordan 1
Nike Outlet Store Online Shopping
Cheap Moncler
Jordan 1
Nike Women Shoes
Pandora Jewelry
Jordan 1 Retro
Adidas Trainers
Balenciaga Shoes
Nike Air Jordan
Asics Shoes
Moncler Jackets
Pandora Charms Outlet
Jordans 1
Pandora Jewelry
Pandora
Pandora
Goyard Handbag
Pandora Charms Outlet
NMD
Nike
Adidas Store
Adidas Official Site
Air Jordan 1 Mid
Nike Canada
New Nike Shoes
Pandora Jewelry Outlet
Pandora Charms
Pandora Charms
Moncler Coats For Women
Ferragamo Belt
Wholesale Retro Jordans
Pandora Outlet
Air Jordan 1
Pandora Charms
Pandora Jewelry Official Site
Discount Jordan Shoes Wholesale
New Nike Shoes
ИмяЦитировать 0
Комментировать
Как не пропустить самое интересное?
Подписывайтесь на наш ежемесячный дайджест!
Спасибо.
Вы подписаны на ежемесячный дайджест.
Пользователь только что записался на курс ""
Спасибо!
Форма отправлена успешно.