Что делать, если твой код ... не очень? Изучаем принципы Clean Code
В этом видео поговорим, на что обратить внимание, когда язык программирования и технологии вы уже освоили, но код оставляет желать лучшего. Как научиться писать чистый код, а также принципы и правила Clean Code.
А также небольшое объявление: в этом месяце мы разыграем книгу Боба Мартина “Чистый код”, для того, чтобы принять участие, вам необходимо найти часть промокода в этом видео, а в следующей части - вторую, соединить и передать нам. “Как” мы расскажем в следующей части видео про клин код. Будьте внимательны. Поехали!
Плейлист по Клин Коду - kzhead.info/channel/PLmqFxxywkatSQoLnnkh7-XjIcGdmo28aJ.html
Когда нужно писать плохой код - kzhead.info/sun/jNdpg7Gyf2Sqp6s/bejne.html
Время "После праздников" уже наступило, поэтому не откладывай обучение!
🔥 Регистрируйся на курсы программирования со скидками от -50% - go.foxminded.ua/3HtEAGF
⌛: Скидка действует до 31.01.2024.
🔥 Новый поток авторского тренинга Сергея Немчинского GRASP and GoF Design patterns стартует уже 01.02.2024
Регистрация 👉 go.foxminded.ua/3NZrOmR
🧠 Регистрируйся прямо сейчас на менторинг
⬇️ Учись у профи ⬇️
🎓 Менторинг:
JAVA - go.foxminded.ua/41U7cT0
PYTHON - go.foxminded.ua/3tMpx7V
C#/.NET - go.foxminded.ua/3Hiyf0A
ANDROID - go.foxminded.ua/41UQWRy
FRONT-END (ANGULAR, REACT) - go.foxminded.ua/3NWvwhh
SALESFORCE Developer - go.foxminded.ua/3Si55Fr
UI/UX дизайн - go.foxminded.ua/48NBY20
Unreal Engine - go.foxminded.ua/3TSm4ze
QA Automation - go.foxminded.ua/3NZi3VQ
IOS разработка - go.foxminded.ua/3RSDJUR
PHP - go.foxminded.ua/3He9Nxs
Unity - go.foxminded.ua/48wDLbV
NODE.JS - go.foxminded.ua/3He9SRM
GOLANG - go.foxminded.ua/47thfPT
Обучение на проекте - go.foxminded.ua/3TSS8mD
Курсы для новичков - go.foxminded.ua/3NZisHQ
🎓 Продвинутые курсы для состоявшихся девелоперов:
Enterprise patterns - go.foxminded.ua/48xDdTi
Алгоритмы и структуры данных - go.foxminded.ua/3tZB6IN
C# NEXT - go.foxminded.ua/3Hh8YnK
🔧 Пробное техническое собеседование со специалистом уровня Senior Developer/ Team Leader - go.foxminded.ua/41SYBQv
👔 Карьерная консультация с Сергеем Немчинским - go.foxminded.ua/3tZXlhI
Есть вопросы по обучению в FoxmindEd? Пишите нам в телеграм - t.me/foxminded
Вы можете стать спонсором канала и получать плюшки - kzhead.info/tools/Vbz7l0COUdLupcY4YtYH0w.htmljoin
❤ FoxmindEd в Instagram: instagram.com/foxminded.ua/
Сайт FoxmindEd для новичков: go.foxminded.ua/3NZZ1Po
Сайт для разработчиков уровня мидл+: go.foxminded.ua/3O0WBzE
FoxmindEd в ФБ: facebook.com/foxmindedco
FoxmindEd в Instagram: instagram.com/foxminded.ua/
Мой Telegram: t.me/nemchinskiyOnBusiness
Для деловых запросов: youtube@foxminded.ua
Тайминг:
00:00 - Вступление
00:47 - Клин код Роберта Мартина
02:34 - Хороший и плохой код
07:11 - Ценность плохого и
09:08 - Качество кода
09:54 - Как прокачать клин код
11:46 - Название
14:39 - Методы
15:38 - Комментарии: хорошие и плохие
17:57 - Форматирование
20:07 - Объекты и структуры
20:19 - Error handling
22:55 - Правила простого дизайна 22:55
(по Кенту Беку)
#nemchinskiy
Время "После праздников" уже наступило, поэтому не откладывай обучение! 🔥 Регистрируйся на курсы программирования со скидками от -50% - go.foxminded.ua/3HtEAGF ⌛: Скидка действует до 31.01.2024.
Ну и куда же без этого анекдота: Как реагируют разные разработчики на фразу "Твой код говно". Junior: - "А-а-а-а меня уволят и я умру!" Middle: - "Что я могу сделать чтобы мой код стал лучше?" Senior: - "Я знаю!" Архитектор: - "А нахрена ты туда полез?!"
Я у таких випадках кажу: "Я ще не рефакторив!"
Это драфтовый коммит)
@@user-gx8gk9ur1n Тогда PR должен быть соответствующий 😁
@@woodzimierz9621 а зачем тогда PR делаешь? 😁
Вы недопоняли, просто кто первый написал корявый код, позаботился о коллегах и их хорошей зп и востребованности😂
Видео о запахах кода (code smells) для меня будет очень даже интересным 🙂
Формат хороший) Спасибо, Сергей+!
Как всегда точно, кратко, информативно и с юмором 💪
Круто! Будет интересно посмотреть тоже самое на примерах)
Формат топ, ви молодець, дивлюсь ваші відео ще з моменту початку навчання програмуванню, зараз вже працюю, але ваші відео допомагають навчатися і далі, тож дякую!
Дякуємо! Який напрямок обрали? Вчились самостійно чи на курсах?
Интересно было бы посмотреть видео с разбором кода (как плохого, так и хорошего).
Есть офигенный нюанс, про который никто не говорит. Никто не сидит и не читает код как книгу просто потому, что интересно. С большой вероятностью тебе дали баг, что что-то не работает, и когда ты будешь через step in проходить все функции в поисках того, что ж там пошло не так, то мелкие однострочные функции будут офигенно бесить. Всё постоянно прыгает фиг знает куда, посмотреть на пару строк выше не вариант из-за того, что ты вообще в другом файле, надо постоянно тыкать мышкой коллстек туда-сюда и получается полная жесть. И никакие красивые имена не спасут. А вот если есть большой метод, в котором всё последовательно написано и работает, то дебажится шикарно. Ограничение по размеру и уровням вложенности это самое надуманное ограничение, которое на самом деле пытается заменить собой принцип DRY - а надо просто придерживаться DRY, а нарезку на методы где попало не пихать.
Работаю в ИТ инженерии больше 10 лет. Вырос сильно по карьерной лестнице до сениора и дальше в управлении. Могу решать самые тяжелые задачи. До сих пор пишу говнокод. Легче отдать мидлам на рефакторинг 😆
пора над тщеславием поработать
Ещё таких видео! Очень интересно смотреть.
8:00 - Как тебе спится, Джон-Серийный программист?
Роберт Мартин - Чистый код + Мартин Фаулер - Рефакторинг = Роберт Фаулер - Рефакторинг чистого кода 🙃
Чистый рефакторинг 🙃
Мартин Мартин - Чистый код: Рефакторинг
Чисто рефакторинг!
Фаулер Роберт - Чистого кода чистый код .... (голосом боярского: Уу уу ... Уу уу... Чистого кода чистый код... Уу уу... А тут матюк и слово рот.... Уу уу...)
Если ваш код с запашком 💩 то зажмите нос и работайте дальше 😊
Сейчас очень велика вероятность получить оффер на вакансию пушечного мяса
Да блин это грустно пипец, и конца не видно
???
6:50 - На самом деле, IoT в частности и немаленькая часть embedded в общем, уже давно ушли в сторону красивого кода, вместо оптимального. Если посмотреть на то, как написаны HAL для современных микрух, то там от оптимальности не то что бы много чего осталось :) Многие даже забивают на DMA и интеррапты, а просто возлагают эти все задачи на RTOS. В итоге, часто вижу проекты, где для задач чуть сложнее чем помигать светодиодом, используют довольно мощные микроконтроллеры с большим объемом памяти, чисто что бы все те абстракции туда потом влезли :)
Интересно, как и всегда) про code smells видео конечно нужно и разбор с примерами тоже было бы здорово
Ваш ответ записан, спасибо)
"Чистый код" обычно хвалят те кто прочитал только начало :) В последнее время слышу много критики этой книги от тех людей которые прочитали её полностью. Судя по отзывам, в начале в книге есть достаточно логичные и полезные мысли, а во второй половине происходит возведение этих практик в абсолют
Говоря что SOLID нарушает половину того что написано в чистом коде 😮 это правда?
@@sky_library_for_novels не могу подтвердить или опровергнуть
@@AntonArhipov без адвоката? )
интересно было бы послушать про code smells!!
Відео сподобалось. Тема актуальна. Давай ще.
Общее правило звучит так: код нужно писать "хороший". Разумеется, выбирая алгоритмы с правильной асимптотикой. И только потом, если будет тормозить и профайлер покажет в каком месте, тогда можно начать оптимизацию (раскручивать циклы, делать все функции инлайн, писать вставки на ассемблере и так далее). В любом случае, будет всегда в запасе "референсный" код, который работает _правильно_. Потому, что оптимизированный код очень трудно развивать и всегда важен пусть медленно, но работающий код. Скажем, удобно написать всяческие тесты на рандомных входных данных и сравнивать результат работы "референсного"/"хорошего" и "оптимизированного" когда. Чтобы по ходу оптимизации не сломать что-нибудь.
На тему безопасности ренейминга: это может быть проблемой, если Вы используете (или вынуждены использовать, ибо до Вас так заведено) автомаппинг. В таком случае желательно сделать (если ещё нет) и прогнать тесты маппинга.
Интересно!
Сподобалося!
Питання. Наприклад пишемо бухгалтерську задачу для місцевого споживача. Оборотно-сальдова відомість на мові замовника просто "оборотка". Як бути з кодом? Писати транслітом "Oborotka", чи англійською "BalanceSheet"?
Две главных боли, которые испытываю при раскурке чужого кода - однобуквенные или сокращённые переменные (привет go) и охулиард слоёв абстракций, вызывающих переполнение мозга (привет жабе).
Добавьте сюда микросервисную архитектуру, где что бы понять, что там в итоге возвращается - нужно ещё выкачать проект (на возможно другом языке и технологиях), и залезть ещё и туда :)
@@feddos4227с микросервисами получилось так-же, как с идеей дробить функции, когда отдельные индивидуумы начали делать кашу из однострочных функций. вот вроде бы здравая идея - а давайте распилим монолит на несколько сервисов, чтоб за каждый отвечала одна команда. а дошли до того, что микросервис на каждый чих, и вместо десяти человек на сервис - десять сервисов на человека. и еще сотня неприкаянных при общем количестве в тыщу. и вот уже со всех митапов и конференций понеслось - "а ведь монолит то не так и плохо было, если он не слишком большой"
иногда в погоне за уменьшением связности кода мы делаем его бессвязным (
жду видео про code smells!
Сделаем
У меня есть книга чистый код. Красивая, жёлтая. Всё что я о ней знаю.
аналогично )
Хочете мені подарувати?😊 Бо напевно монітор який стоїть на ній занадто високо 😂
Мартин и Фаулер это два разных человека, а Чистый Код вообще не человек (с) анекдот
НУЖНО ВИДЕО ПРО DRY В НеООП Мало материалов про клинкод для неООП-фреймворков и языков, а это значительная часть фронтэнда. Например, мне приходится писать много на Vue, куча похожих компонентов, но не совсем ясно, как избежать дублирования кода. Если бы было наследование, я бы им пользовался, но там нет наследования
На хаскеле тоже отступы важны, правда только в части синтаксических конструкций
Встречается однажды программист с хорошим кодом и пользователь с fps ниже пульса в два раза...
Наверное в Cities Skyline 2 очень хорошие программисты, и написали очень хороший код )))
Code Smells +++
Видео про code smells!!!!!
Хороший кот это тот, который мурчит и не ссыт в тапки. Всё остальное это плохой кот. Вот
А теперь представим себе кота, который мурчит и срёт. Мурчит? Да. Ссыт? Нет. Значит хороший :D
С перламутр...пуговицами это классика😅
Да конечно видеоролик классный
Обучить чатгпт тому как пишут код у вас в конторе, а потом прогонять свой код, через эту модель)))
В rust проблему форматирования решили на уровне языка. Команда "cargo fmt" форматирует код в проекте по стандарту разработчиков языка
dont care
Скромно предположу - Учиться Всем Адекватности мира и добра
Оптимизированый код, это код для которого выполнена оптимизация по конкретным критериям, и они могут быть разными. По простоте или по структуре (это тоже оптимизация). По памяти. По скорости. По размеру самого кода. По комбинации критериев. Автоформатирование это зашкварно. Конечно должны быть рекомендуемые правила форматирования, но это в первую очередь рекомендация. Хотя джависты со своими скобками, наверное, достали всех, и автоформат это единственный выход.
Давно пора из идеи и тому подобных вытащить форматеры кода в мавен плагин или в другие сборщики и форматировать в автоматическом режиме при пушах в git.
Хороший код - за которий платят деньги. То есть, как минимум, он неплох :)
тот день копгда я понял что ненавижу всей душой как пользователь и программист с 20+(комерчиский ессно) стажем "хороший" код. больше я ненавижу развечтрои зеленых и вокнутых.
17:53
Шукаю хорошого джава стриптизера для допомоги або чуть гіршого для спільного проекту)
Що за проект? І на чому бек пишите?
@@Klerfe нема і нікого і нічого ще
Reformat только для ИЗМЕНЕННОГО кода, никогда для ВСЕГО файла! Вот тогда не будет ни лишних изменений кода, ни, тем более, конфликтов.
недооцененный коммент
В смысле 500 не показывать 🌚не по-христиански это 😂
Ха. Книга уже есть. Так что без меня.
+
Автоформатирование - это гадость, от которой надо избавляться. А программистов, неспособных отформатировать нормально, надо просто гнать подальше - никогда такие хороший код не напишут. И никаких конфликтов при мёрдже не будет, если не форматировать код, который ты не менял (в том числе, сюрприз, не применять автоформатирование ко всему файлу).
Это все? Как то мало, слишком очевидные вещи
Первый.
Чистый?
Поздравления
Ребят, хорош заниматься всяким кодо-фетишем. Код, который работает и делает то, что надо - хороший, а тот, который не делает - плохой. И нет тут идеала. Практически всегда тот, кто пишет и тот, кто читает, имеют разные модели мышления. И как бы не полировался код, он всегда будет непонятен с разбегу другому программисту. Поэтому, решайте проблемы бизнеса, помогайте зарабатывать ему деньги. Это главное, а не сам код - он вторичен.