Что делать, если твой код ... не очень? Изучаем принципы Clean Code

Поділитися
Вставка
  • Опубліковано 8 лют 2025

КОМЕНТАРІ • 90

  • @SergeyNemchinskiy
    @SergeyNemchinskiy  4 місяці тому

    💪Новый поток advanced тренинга Enterprise patterns стартует 2.12 - go.foxminded.ua/48xDdTi

  • @sergeypekar1058
    @sergeypekar1058 Рік тому +67

    Ну и куда же без этого анекдота:
    Как реагируют разные разработчики на фразу "Твой код говно".
    Junior: - "А-а-а-а меня уволят и я умру!"
    Middle: - "Что я могу сделать чтобы мой код стал лучше?"
    Senior: - "Я знаю!"
    Архитектор: - "А нахрена ты туда полез?!"

    • @woodzimierz9621
      @woodzimierz9621 Рік тому +6

      Я у таких випадках кажу: "Я ще не рефакторив!"

    • @БорисКрасных-ц8н
      @БорисКрасных-ц8н Рік тому +2

      Это драфтовый коммит)

    • @sergeypekar1058
      @sergeypekar1058 Рік тому

      @@БорисКрасных-ц8н Тогда PR должен быть соответствующий 😁

    • @sergeypekar1058
      @sergeypekar1058 Рік тому

      @@woodzimierz9621 а зачем тогда PR делаешь? 😁

  • @sokolov_sergey
    @sokolov_sergey Рік тому +37

    Вы недопоняли, просто кто первый написал корявый код, позаботился о коллегах и их хорошей зп и востребованности😂

  • @SerzhNesteruk
    @SerzhNesteruk Рік тому +12

    Видео о запахах кода (code smells) для меня будет очень даже интересным 🙂

  • @Максим-т4ю6ъ
    @Максим-т4ю6ъ Рік тому

    Формат топ, ви молодець, дивлюсь ваші відео ще з моменту початку навчання програмуванню, зараз вже працюю, але ваші відео допомагають навчатися і далі, тож дякую!

    • @alexandrapersukova
      @alexandrapersukova Рік тому

      Дякуємо! Який напрямок обрали? Вчились самостійно чи на курсах?

  • @p.bakuard8648
    @p.bakuard8648 Рік тому +7

    Интересно было бы посмотреть видео с разбором кода (как плохого, так и хорошего).

    • @QwDragon
      @QwDragon Рік тому +2

      Есть офигенный нюанс, про который никто не говорит. Никто не сидит и не читает код как книгу просто потому, что интересно. С большой вероятностью тебе дали баг, что что-то не работает, и когда ты будешь через step in проходить все функции в поисках того, что ж там пошло не так, то мелкие однострочные функции будут офигенно бесить. Всё постоянно прыгает фиг знает куда, посмотреть на пару строк выше не вариант из-за того, что ты вообще в другом файле, надо постоянно тыкать мышкой коллстек туда-сюда и получается полная жесть. И никакие красивые имена не спасут. А вот если есть большой метод, в котором всё последовательно написано и работает, то дебажится шикарно. Ограничение по размеру и уровням вложенности это самое надуманное ограничение, которое на самом деле пытается заменить собой принцип DRY - а надо просто придерживаться DRY, а нарезку на методы где попало не пихать.

  • @borisisavnin9983
    @borisisavnin9983 Рік тому +2

    Формат хороший)
    Спасибо, Сергей+!

  • @feddos4227
    @feddos4227 Рік тому +4

    6:50 - На самом деле, IoT в частности и немаленькая часть embedded в общем, уже давно ушли в сторону красивого кода, вместо оптимального. Если посмотреть на то, как написаны HAL для современных микрух, то там от оптимальности не то что бы много чего осталось :) Многие даже забивают на DMA и интеррапты, а просто возлагают эти все задачи на RTOS. В итоге, часто вижу проекты, где для задач чуть сложнее чем помигать светодиодом, используют довольно мощные микроконтроллеры с большим объемом памяти, чисто что бы все те абстракции туда потом влезли :)

  • @torrvic1156
    @torrvic1156 5 місяців тому

    Прекрасное видео! Спасибо Сергей! Жаль, что не сопровождаете кодом, как Tim Corey например, но и на том, что есть спасибо большое!

  • @aanistratenko
    @aanistratenko Рік тому +3

    Как всегда точно, кратко, информативно и с юмором 💪

  • @AnastasiiaMorozova-x8y
    @AnastasiiaMorozova-x8y Рік тому +1

    Интересно, как и всегда) про code smells видео конечно нужно и разбор с примерами тоже было бы здорово

  • @illia4228
    @illia4228 Рік тому

    Круто! Будет интересно посмотреть тоже самое на примерах)

  • @AntonArhipov
    @AntonArhipov Рік тому +3

    "Чистый код" обычно хвалят те кто прочитал только начало :) В последнее время слышу много критики этой книги от тех людей которые прочитали её полностью. Судя по отзывам, в начале в книге есть достаточно логичные и полезные мысли, а во второй половине происходит возведение этих практик в абсолют

    • @Sky_Lib
      @Sky_Lib Рік тому

      Говоря что SOLID нарушает половину того что написано в чистом коде 😮 это правда?

    • @AntonArhipov
      @AntonArhipov Рік тому

      @@Sky_Lib не могу подтвердить или опровергнуть

    • @rebrov_vyacheslav
      @rebrov_vyacheslav Рік тому

      @@AntonArhipov без адвоката? )

  • @Fenixtremo
    @Fenixtremo Рік тому +3

    Работаю в ИТ инженерии больше 10 лет. Вырос сильно по карьерной лестнице до сениора и дальше в управлении. Могу решать самые тяжелые задачи. До сих пор пишу говнокод. Легче отдать мидлам на рефакторинг 😆

    • @rebrov_vyacheslav
      @rebrov_vyacheslav Рік тому

      пора над тщеславием поработать

  • @vitaliy0192
    @vitaliy0192 Рік тому +1

    Ещё таких видео! Очень интересно смотреть.

  • @redneck_prm5429
    @redneck_prm5429 Рік тому +4

    Две главных боли, которые испытываю при раскурке чужого кода - однобуквенные или сокращённые переменные (привет go) и охулиард слоёв абстракций, вызывающих переполнение мозга (привет жабе).

    • @feddos4227
      @feddos4227 Рік тому

      Добавьте сюда микросервисную архитектуру, где что бы понять, что там в итоге возвращается - нужно ещё выкачать проект (на возможно другом языке и технологиях), и залезть ещё и туда :)

    • @redneck_prm5429
      @redneck_prm5429 Рік тому

      @@feddos4227с микросервисами получилось так-же, как с идеей дробить функции, когда отдельные индивидуумы начали делать кашу из однострочных функций.
      вот вроде бы здравая идея - а давайте распилим монолит на несколько сервисов, чтоб за каждый отвечала одна команда.
      а дошли до того, что микросервис на каждый чих, и вместо десяти человек на сервис - десять сервисов на человека. и еще сотня неприкаянных при общем количестве в тыщу.
      и вот уже со всех митапов и конференций понеслось - "а ведь монолит то не так и плохо было, если он не слишком большой"

    • @rebrov_vyacheslav
      @rebrov_vyacheslav Рік тому +1

      иногда в погоне за уменьшением связности кода мы делаем его бессвязным (

  • @MichaelKondrashin
    @MichaelKondrashin Рік тому +2

    Общее правило звучит так: код нужно писать "хороший". Разумеется, выбирая алгоритмы с правильной асимптотикой. И только потом, если будет тормозить и профайлер покажет в каком месте, тогда можно начать оптимизацию (раскручивать циклы, делать все функции инлайн, писать вставки на ассемблере и так далее). В любом случае, будет всегда в запасе "референсный" код, который работает _правильно_. Потому, что оптимизированный код очень трудно развивать и всегда важен пусть медленно, но работающий код. Скажем, удобно написать всяческие тесты на рандомных входных данных и сравнивать результат работы "референсного"/"хорошего" и "оптимизированного" когда. Чтобы по ходу оптимизации не сломать что-нибудь.

  • @chugaister7538
    @chugaister7538 Рік тому +3

    8:00 - Как тебе спится, Джон-Серийный программист?

  • @nicolascooler5785
    @nicolascooler5785 Рік тому +2

    интересно было бы послушать про code smells!!

  • @АлександрНевельский-л2з

    На тему безопасности ренейминга: это может быть проблемой, если Вы используете (или вынуждены использовать, ибо до Вас так заведено) автомаппинг.
    В таком случае желательно сделать (если ещё нет) и прогнать тесты маппинга.

  • @GenaTolstij
    @GenaTolstij Рік тому +2

    Хороший кот это тот, который мурчит и не ссыт в тапки. Всё остальное это плохой кот. Вот

    • @muggzzzzz
      @muggzzzzz 9 місяців тому

      А теперь представим себе кота, который мурчит и срёт.
      Мурчит?
      Да.
      Ссыт?
      Нет.
      Значит хороший
      :D

  • @Александр-о5о3й

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

  • @CrossRoad7
    @CrossRoad7 Рік тому

    Наверное в Cities Skyline 2 очень хорошие программисты, и написали очень хороший код )))

  • @rufussnowmover8914
    @rufussnowmover8914 Рік тому

    НУЖНО ВИДЕО ПРО DRY В НеООП
    Мало материалов про клинкод для неООП-фреймворков и языков, а это значительная часть фронтэнда. Например, мне приходится писать много на Vue, куча похожих компонентов, но не совсем ясно, как избежать дублирования кода. Если бы было наследование, я бы им пользовался, но там нет наследования

    • @MariaEsenina
      @MariaEsenina 7 місяців тому

      DRY - это тоже троллинг и запросто спотыкается о реальность, либо порождает архитектурное безумие, так как вы будете вынуждены связывать совершенно несвязанные друг с другом сущности.
      Допустим у вас в проекте есть классы: "утка", "корабль", "самолёт" и человек". Корабль и утка плавают и в коде их "плавания" может быть немало общего, далее самолёт и утка летают, также утка умеет ходить на двух ногах как и человек. Удачи вам здесь с DRY в проектировании методов. Либо связывайте классы между собой и тогда утка - у нас сверх существо, которое умеет всё! Clean Code сцуко!

  • @Mralex22801
    @Mralex22801 Рік тому +3

    У меня есть книга чистый код. Красивая, жёлтая. Всё что я о ней знаю.

    • @Infinity-ua
      @Infinity-ua Рік тому

      аналогично )

    • @Sky_Lib
      @Sky_Lib Рік тому

      Хочете мені подарувати?😊 Бо напевно монітор який стоїть на ній занадто високо 😂

  • @ЭдуардВанярха
    @ЭдуардВанярха Рік тому

    Відео сподобалось. Тема актуальна. Давай ще.

  • @StanBo_ua
    @StanBo_ua Рік тому +10

    Роберт Мартин - Чистый код
    +
    Мартин Фаулер - Рефакторинг
    =
    Роберт Фаулер - Рефакторинг чистого кода
    🙃

    • @SerzhNesteruk
      @SerzhNesteruk Рік тому +2

      Чистый рефакторинг 🙃

    • @linuxoidovich
      @linuxoidovich Рік тому +8

      Мартин Мартин - Чистый код: Рефакторинг

    • @woodzimierz9621
      @woodzimierz9621 Рік тому +1

      Чисто рефакторинг!

    • @GenaTolstij
      @GenaTolstij Рік тому

      Фаулер Роберт - Чистого кода чистый код .... (голосом боярского: Уу уу ... Уу уу... Чистого кода чистый код... Уу уу... А тут матюк и слово рот.... Уу уу...)

  • @Kudriako
    @Kudriako Рік тому +2

    Мартин и Фаулер это два разных человека, а Чистый Код вообще не человек (с) анекдот

  • @xvoidee
    @xvoidee Рік тому +6

    Если ваш код с запашком 💩 то зажмите нос и работайте дальше 😊

  • @woodzimierz9621
    @woodzimierz9621 Рік тому

    Питання. Наприклад пишемо бухгалтерську задачу для місцевого споживача. Оборотно-сальдова відомість на мові замовника просто "оборотка". Як бути з кодом? Писати транслітом "Oborotka", чи англійською "BalanceSheet"?

  • @Stepanraikevich
    @Stepanraikevich Рік тому +3

    жду видео про code smells!

  • @IliaS-s2e
    @IliaS-s2e Рік тому

    Обучить чатгпт тому как пишут код у вас в конторе, а потом прогонять свой код, через эту модель)))

  • @fromillia
    @fromillia Рік тому +6

    Сейчас очень велика вероятность получить оффер на вакансию пушечного мяса

    • @pusika3
      @pusika3 Рік тому

      Да блин это грустно пипец, и конца не видно

    • @grigoriykarpenko235
      @grigoriykarpenko235 Рік тому

      ???

  • @levmedvedev
    @levmedvedev Рік тому

    Интересно!

  • @АлександрКубраков-у2ш

    В rust проблему форматирования решили на уровне языка. Команда "cargo fmt" форматирует код в проекте по стандарту разработчиков языка

  • @woodzimierz9621
    @woodzimierz9621 Рік тому

    Сподобалося!

  • @CJSurv
    @CJSurv Рік тому

    На хаскеле тоже отступы важны, правда только в части синтаксических конструкций

  • @yevhenhrafov228
    @yevhenhrafov228 Рік тому

    С перламутр...пуговицами это классика😅

  • @QwDragon
    @QwDragon Рік тому

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

  • @slxb7743
    @slxb7743 Рік тому

    Оптимизированый код, это код для которого выполнена оптимизация по конкретным критериям, и они могут быть разными.
    По простоте или по структуре (это тоже оптимизация).
    По памяти. По скорости. По размеру самого кода.
    По комбинации критериев.
    Автоформатирование это зашкварно.
    Конечно должны быть рекомендуемые правила форматирования, но это в первую очередь рекомендация.
    Хотя джависты со своими скобками, наверное, достали всех, и автоформат это единственный выход.

    • @taller8624
      @taller8624 Рік тому

      Давно пора из идеи и тому подобных вытащить форматеры кода в мавен плагин или в другие сборщики и форматировать в автоматическом режиме при пушах в git.

  • @solllvent
    @solllvent Рік тому

    Хороший код - за которий платят деньги. То есть, как минимум, он неплох :)

  • @igorchesnokov482
    @igorchesnokov482 Рік тому +1

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

  • @Али-Мухаммад-Закарьяев

    Видео про code smells!!!!!

  • @andvolodko
    @andvolodko Рік тому +1

    Code Smells +++

  • @apdgslfhsodbna
    @apdgslfhsodbna 10 місяців тому

    В смысле 500 не показывать 🌚не по-христиански это 😂

  • @oleg10021989
    @oleg10021989 Рік тому

    Да конечно видеоролик классный

  • @mickle-ak
    @mickle-ak Рік тому

    Reformat только для ИЗМЕНЕННОГО кода, никогда для ВСЕГО файла!
    Вот тогда не будет ни лишних изменений кода, ни, тем более, конфликтов.

  • @alexandergornostaev610
    @alexandergornostaev610 Рік тому

    тот день копгда я понял что ненавижу всей душой как пользователь и программист с 20+(комерчиский ессно) стажем "хороший" код. больше я ненавижу развечтрои зеленых и вокнутых.

  • @MariaEsenina
    @MariaEsenina 7 місяців тому

    Стив Макконелл - база, Боб Мартин - кринж. Серьёзно, clean code от дяди Боба - это тормозной архитектурный ад, который при всё нисколько не помогает писать код быстрее и понятнее. При этом Стив помимо своего ИМХО изучил какие-то исследования, искренне пытаясь вывести наилучшие практики, Боб: "Миш мне пох*й, я так чувствую!" (с).

  • @zefffirka8963
    @zefffirka8963 Рік тому

    Шукаю хорошого джава стриптизера для допомоги або чуть гіршого для спільного проекту)

    • @Klerfe
      @Klerfe Рік тому

      Що за проект? І на чому бек пишите?

    • @zefffirka8963
      @zefffirka8963 Рік тому

      @@Klerfe нема і нікого і нічого ще

  • @Gazovchik
    @Gazovchik Рік тому +1

    Скромно предположу
    -
    Учиться
    Всем Адекватности мира и добра

  • @geldelian
    @geldelian Рік тому

    17:53

  • @NovikovEugene84
    @NovikovEugene84 Рік тому

    Ха. Книга уже есть. Так что без меня.

  • @ДенисСаранин-м1и

    Это все? Как то мало, слишком очевидные вещи

  • @krivodeling7925
    @krivodeling7925 9 місяців тому

    +

  • @Dark_Main_Alpha
    @Dark_Main_Alpha 6 місяців тому

    Чистые кода не существует что значит чистые значит не чего

  • @nickita.zarubin
    @nickita.zarubin Рік тому +1

    Первый.

  • @torrvic1156
    @torrvic1156 5 місяців тому

    Ох и противоречивая тема. С одной стороны, вроде удобно отлавливать баги, когда много кода в одном файле, а не скачет всё по 100 файлам, но с другой это порой выглядит как такая чушь. У меня вот была ситуация, когда код дублировался и создавал баг из-за того, что я на класс навешал функционал, не свойственный ему по названию. И при вызове класса производилось некое действие и после него оно также производилось. Нет в общем волшебной пилюли (или silver bullet по заморски).