реклама
разместить

Код должен решать задачу.
Оптимальным способом с минимальными издержками.
Не должен он быть эстетичным. Не должен быть красивым. Не должен радовать глаз разработчика.
Задачу он, блэт, поставленную должен решать.
Красивый и «эстетичный» код не гарантирует и даже не коррелирует с качеством.
Чистота кода может снижать издержки (стоимость поддержки и сложность онбординга), и то не всегда.
Но в огромном количестве случаев для бизнеса нести эти издержки выгоднее, чем «делать красиво».

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

7

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

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

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

Правда есть два момента.
1. Далеко не всегда мы пишем с нуля, иногда приходим в функционирующий слипшийся спагетти-монолит. Тут конечно надо придерживаться золотой середины и не рефакторить весь проект в рамках первой же задачи.
2. Среди разрабов много таких, кто понятия не имеет, какой код - «красивый», но упорно его делает. Конечно, это потеря времени. Потом приходит другой и переделывает. Это проблема.

В общем, красивый код - важно даже не в долгосрочной, а в очень даже краткосрочной перспективе именно потому, что ресурсов на его поддержку (а 80% времени мы поддерживаем и развиваем) тратится гораздо меньше.

14

а потом оказывается как у тинька "клиенты необоснованно обогатились на обмене валют"

а потом разрабы в команде друг друга душат и дедовщину новичкам устраивают по "качеству" кода

хотя с частью тезисов я полностью согласен, просто у этого подхода полно минусов

2

По новичкам - тяжело в учении, легко в бою 😉 Грамотный тимлид не допустит дедовщины на проекте!
"Душат друг друга" и "дедовщина" – это показатель слабой культуры разработки, неслаженной команды и/или отсутствия лидера, который вовремя может остановить перегибы. Мы считаем, что описанные в статье вещи способствуют порядку, при этом их выбор в каждой команде, конечно, свой)

5

а за что душить? многие из описанных вещей делаются автоматически, до того как их увидит команда

1

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