SOLID принципы: OCP (Открытости/закрытости (Open Closed Principle)

  Рет қаралды 120,719

Sergey Nemchinskiy

Sergey Nemchinskiy

Күн бұрын

Пікірлер: 191
@SergeyNemchinskiy
@SergeyNemchinskiy 2 ай бұрын
💪Новый поток advanced тренинга Enterprise patterns стартует 2.12 - go.foxminded.ua/3BDbBAL
@МаксимЧернявский-д9ш
@МаксимЧернявский-д9ш 3 жыл бұрын
Жду пока он скажет - "Я больше не Сергей Немчинский, теперь я имплементирую интерфейс Сергея Немчинского!" )) Спасибо за видео, как всегда доходчиво и понятно
@pi4alka_screamo
@pi4alka_screamo Жыл бұрын
ахах, в голос))))))))))))))))))
@xandrop
@xandrop Жыл бұрын
А так как Такое запомнить нельзя, то прочитает со смартфона
@mikhailanisimov2160
@mikhailanisimov2160 4 жыл бұрын
"В промышленном софте всегда всё протестировано", - хорошая шутка. =)
@Manuel-j3q
@Manuel-j3q 4 жыл бұрын
Смеялись всем тестовым отделом.
@kirillshamyakov6649
@kirillshamyakov6649 4 жыл бұрын
Видос SOLID’ный, спасибо, с меня луцк
@Corvus_I_am
@Corvus_I_am Жыл бұрын
Я не знаю как максимально вежливо подсветить, наверное, все равно обижу спикера, но все же повторю, что исключение хезитационных пауз из речи стало бы колоссальной её оптимизацией. Ещё раз спасибо за труд. С признательностью и благодарностью.
@strekozart
@strekozart 4 жыл бұрын
Сергей спасибо за видео! Мне очень нравится как вы вкладываетесь в объяснение, очень круто!
@AnnaIsHere
@AnnaIsHere 4 жыл бұрын
и оформление. И вот эти штучки внизу видео, отрезочки. Мимими!
@sealkeen
@sealkeen 3 жыл бұрын
На самом деле, спасибо большое, Сергей, пересматриваю во время тренинга, правда, не у вас, к сожалению, а в епаме, но всё-таки. Во время написания кода Ваши рекомендации, когда на заднем плане идут, реально отлично помогают при рефакторинге архитектуры приложения. Пишу классы для доступа к базе данных и интерфейс, где у меня очень высокая зависимость классов друг от друга, а потом слышу с заднего плана: надо просто вынести клиентский код в интерфейс, и реально выношу его в интерфейс, и оно всё в результате отлично спроектировано получается.
@АндрейГрицай-л1ф
@АндрейГрицай-л1ф 4 жыл бұрын
Очень простое і доступное объяснение. Даже есть практический пример из жизни, что очень помогает понять. Спасибо большое! Мне очень нравится ваши видео. ☺
@dimitro.cardellini
@dimitro.cardellini 4 жыл бұрын
Перечитал Роберта Мартина. Специально, чтобы убедиться в том, что я правильно понимаю Принцип Отркытоти / Закрытости (OCP). . Так, вот, этот принцип не совсем про Классы и Интерфейсы, наследование и реализацию, и уж тем более, не про "замочки" на классах. Это все, конечно правильно, но, это все частные способы вносить изменения в код, который, кстати, не обязательно соответствует OCP. И применение к нему описанных техник изменения сохранит это свойство кода. . OCP о том, что следуя SRP мы также должны учитывать, что отдельные подзадачи могут иметь разные решения и выделять соответствующие абстракции, защищая этим самым решение общей задачи от изменений, и делая такое решение открытым для расширения. Т.е. OCP -- это про декомпозицию кода. Именно, следуя OCP мы должны выделить наши зависимости, т.е. проанализировать, какие подзадачи могут иметь альтернативные решения, оценить вероятность такого измнения, что в свою очередь позволит не плодить лишнии абстракции. . На простом примере: Мы делаем функцию сортировку и используем в алгоритме простую конструкцию: a < b, чтобы понять надо ли нам поменять элементы местами или нет. Мы находимся в рамках SRP (т.е. наш алгоритм имеет одного Актора, решает одну задачу). Но, если нам надо будет реализовать сортировку уже по возрастанию (убыванию), то нам надо будет менять алгоритм, чего собственно мы и хотим избежать. . Так вот OCP говорит нам о том, что наш алгоритм сортировки должен абстрагироваться от реализации отношения порядка (что помимо всего прочего позволит абстрагироваться еще и по типу данных элементов коллекции). . Видео из объяснения OCP вылилось в расказ про DIP, где зависимости нам уже даны. OCP -- про выявление зависимостей и создание абстракций. . На 9:20 Сергей дает пример Клиентского класса и Серверного класса, и говорит о том, что это нарушает OCP потому, что мы не можем расширить их взаимодействие. И здесь очень опасная и хитрая ошибка, которая заключается в том, что нам не надо расширять это взаимодействие. Нам надо расширить функциональность, а не взаимодействие отдельных двух компонентов. . В заключении, перефразирую Кота Матроскина: - чтобы инвертировать что-нибудь "ненужное", сначала надо абстрагироваться по этому "ненужному", а мы об этом в видео не говорим ...
@sashchernuh
@sashchernuh 4 жыл бұрын
"Видео из объяснения OCP вылилось в расказ про DIP, где зависимости нам уже даны. OCP -- про выявление зависимостей и создание абстракций." - спасибо за идею!
@ivanandreev9571
@ivanandreev9571 4 жыл бұрын
Подскажите пожалуйста, как абстрагироваться от отношения порядка в случае с сортировкой?
@dimitro.cardellini
@dimitro.cardellini 4 жыл бұрын
@@ivanandreev9571 заменить "a < b" на "compare(a, b) < 0" -- это будет OCP. Это позволит изменять порядок сортировки, не меняя при этом сам алгоритм сортировки. А потом по DIP надо принимать функцию conpare на вход влгоритма сортировки.
@ivanandreev9571
@ivanandreev9571 4 жыл бұрын
@@dimitro.cardellini то есть мы создадим целый класс компаратора и интерфейс для него?
@dimitro.cardellini
@dimitro.cardellini 4 жыл бұрын
@@ivanandreev9571 ну, я бы предпочёл лямбду )
@ДанилаПермогорский-т6р
@ДанилаПермогорский-т6р 4 жыл бұрын
Замечательный цикл видео, спасибо Сергей!
@Бензини
@Бензини 4 жыл бұрын
у Вас такие прикольные лекции записаны, давно не было, делайте побольше лекций)
@СильвестрСергеев-л9з
@СильвестрСергеев-л9з 4 жыл бұрын
Давно не заходил, отличный формат видео. Зашел прям очень.
@sergem2794
@sergem2794 4 жыл бұрын
Отличная подборка. Давно ждал SOLID
@egorvafin1978
@egorvafin1978 2 жыл бұрын
Сергей, спасибо за видео про SOLID
@demidovmaxim1008
@demidovmaxim1008 4 жыл бұрын
Большое спасибо за выпуск!!!
@Zlobusz
@Zlobusz 4 жыл бұрын
Завязка на интерфейсы - это круто!
@grommaks
@grommaks 4 жыл бұрын
Харош, было интересно 🙃 спасибо
@boberbober8083
@boberbober8083 4 жыл бұрын
Маркером по бумаге.. ууух, мурашки по коже, не смог досмотреть но лайк поставил.
@MrBulat1
@MrBulat1 4 жыл бұрын
Спасибо за видео, приятно было слушать.
@simplechannel7859
@simplechannel7859 3 жыл бұрын
Сергей, спасибо!
@artur1998g
@artur1998g 4 жыл бұрын
Спасибо большое за видеоролики. Очень доходчиво объясняешь.
@alexanderraf5553
@alexanderraf5553 4 жыл бұрын
Полиморфная трактовка от дяди Боба крута!!!!!!) Сергей, вы гений обьяснять сложное простым человеческим языком.спасибо!))))
@johnsnow2810
@johnsnow2810 4 жыл бұрын
Очень сумбурное объяснение. Если бы сам не знал бы принципы solid, то из этого видео возможно не понял бы. Ну и да, доску нужно ближе и маркеры темнее или вообще перейти на запись видео с экрана, с электронной доской. В любом случае спасибо за видео! Очень полезно послушать многие вещи, то как их другие понимают.
@rus1006
@rus1006 2 жыл бұрын
я тоже ничего не понял. однако буква s из его объяснения понятна. вообще то я думал расширение под собой подразумевает применение паттернов
@UserUser-yk9bt
@UserUser-yk9bt 10 ай бұрын
Спасибо большое за видео))
@СергейКарпиченко-с6б
@СергейКарпиченко-с6б 4 жыл бұрын
Спасибо большое за видео, супер!
@veldan1202
@veldan1202 4 жыл бұрын
Видосики стали превосходными/)))
@shkippitor1895
@shkippitor1895 4 жыл бұрын
Спасибо за Ваш труд)
@IROnMAn-ze6op
@IROnMAn-ze6op 4 жыл бұрын
Не понял насчёт трактовки от Мартина: нам что, нужно создавать новый класс, который заново будет имплементировать интерфейс, только поведение уже будет другое, чем у класса, со старой реализацией?
@SergeyNemchinskiy
@SergeyNemchinskiy 4 жыл бұрын
примерно так. но можно от старого унаследоваться
@IROnMAn-ze6op
@IROnMAn-ze6op 4 жыл бұрын
@@SergeyNemchinskiy если не унаследоваться от старого, то всё равно не понимаю. У нас есть новый класс с новой реализацией, зачем тогда сохранять старый?
@kisurov
@kisurov 4 жыл бұрын
@@IROnMAn-ze6op Новый класс может быть обёрткой над старым, дополняя его функционал, а не повторяя его целиком
@truenerdofbotva5831
@truenerdofbotva5831 4 жыл бұрын
@@kisurov но у нас же тогда в итоге окажется по десять обёрток над каждым классом, как с этим быть? Или предполагается, что код будет писаться сразу как надо, и изменения будут малочисленными?
@БендерЗадунайский-щ9ы
@БендерЗадунайский-щ9ы 4 жыл бұрын
спасибо! ждем про Л😀 ... и поставте маркерную доску. удобная дешевая штука, и на ней всё видно! не то что на этой. сами посмотрите(с телефона 😀)
@-boiadeiro-
@-boiadeiro- 4 жыл бұрын
осталось 3 принципа и мы наконец познаем силу ООП!
@hmixa
@hmixa 4 жыл бұрын
Использование оператора new смерть для тестов. Работайте через интерфейсы, скармливая их вашему коду снаружи и будет вам счастье!
@anti1am3r
@anti1am3r 4 жыл бұрын
Где то вам все равно создавать экземпляры надо )
@MegaMrTan
@MegaMrTan 4 жыл бұрын
Здравствуйте, благодарю за труд; пишите, плз, жирнее или маркеры смените))
@freydrauver249
@freydrauver249 3 жыл бұрын
За серію відео велике дякую! P. S. Заберіть хтось в Сергія зелений маркер.
@TimC0x
@TimC0x 4 жыл бұрын
9:50 почему же "прокси", это же адаптер, он позволяет соединить одну систему с другой. прокси это если об подмене реального объекта заглушкой
@lyloo6577
@lyloo6577 4 жыл бұрын
Подразумевается, наверное, что требуемый объект будет инициализирован или найден при необходимости. Адаптер это про другое, про создание одного интерфейса поверх другого/других для удобства использования
@andrewkovalchuk1665
@andrewkovalchuk1665 4 жыл бұрын
Сергей, ты случайно в конце не оговорился про IoC и Dependency Inversion? Может имел ввиду Dependency Injection, как имплементацию IoC, а используя Dependency Inversion принцип мы можем подкидывать в IoC контейнер нужные нам реализации интерфейса? В данном случае оговорка, как по мне, достаточно существенная и может ввести в заблуждение тех, кто недавно с этим столкнулся... А так все по делу. Спасибо за то что ты делаешь. Лойк!)
@mikhaillucky8130
@mikhaillucky8130 4 жыл бұрын
да, это оговорка, еще чуть раньше он принцип назвал паттерном, но если человек захочет разобраться в этой теме, данных видосов будет мало, а небольшие неточности исчезнут в процессе.
@andrewkovalchuk1665
@andrewkovalchuk1665 4 жыл бұрын
Так то коммент я писал с целью обратить внимание тех, кто только столкнулся с этим. На собесе, конечно, лучше так не оговариваться...
@sh1maru
@sh1maru 4 жыл бұрын
А как этот принцип сочетается с тем, что бизнес требования, а за ними бизнес-логика, меняются по два раза в день и всем в принципе заранее понятно, что так и будет?
@jossefal1957
@jossefal1957 4 жыл бұрын
Отличное видео
@sergey.stafeev
@sergey.stafeev 4 жыл бұрын
Непонятно, почему я не могу добавить метод в существующий класс, чем плодить новые классы наследованием и там добавлять? И если правок будет много, то это сколько ж наследований будет.
@alexandernifanin7366
@alexandernifanin7366 4 жыл бұрын
Да ерунда, конечно. Я бы так сказал, что добавлять можно, а вот менять - проблемно, т.к. зависимые классы и клиенты тоже придётся менять. Проблема может быть в интерфейсе. Если туда добавить метод, его придётся добавлять во все наследники.
@виталийвольф-у4т
@виталийвольф-у4т 4 жыл бұрын
Вопрос, так а конструкция Роберта Мартина(1996 год), я не понял как там тогда "расширять" функционал, если и старый класс(функционал), и новый, зависят от одного интерфейса. как мы добавим что-т новое, если интерфейс у них один?
@nrnwest
@nrnwest 2 жыл бұрын
функционал можно только добавить но не трогая интерфейс а вот первый вариант гибче выходит, там мы наследуюем и добавляем любой функционал (в интерфейс) не нарушай базовый интерфейс ) чет Сергей не договаривает или просто на тренинг так манит )))
@r2d2925
@r2d2925 4 жыл бұрын
Жду продолжений! очень доходчево и легко для понимания
@mashinostroitel
@mashinostroitel 4 жыл бұрын
Супер. Спасибо :)
@romanmotovilov129
@romanmotovilov129 4 жыл бұрын
Спасибо! Ставлю лайк перед просмотром! А теперь можно и посмтотреть...
@ZeroBone
@ZeroBone 4 жыл бұрын
6:57 Реализация интерфейсов в UML обозначается пунктирной линией (со стрелкой как при наследовании на конце).
@khusamalfas2121
@khusamalfas2121 3 жыл бұрын
Большое спасибо
@AnaRxistBoD
@AnaRxistBoD 4 жыл бұрын
Такой вопрос: а что насчет расширения функционала через extensions (extension methods)? Насколько это соответствует принципу "открытости-закрытости"?
@turchik5763
@turchik5763 4 жыл бұрын
Сергей, запишите подробное видео про android разработку, с чего начать и т д. Хочется услышать от вас рекомендации новичку
@МихаилЗавитаев-м4б
@МихаилЗавитаев-м4б 3 жыл бұрын
Спасибо!
@AndriySydorka
@AndriySydorka 4 жыл бұрын
Дядя Сережа тащит!
@dsalodki
@dsalodki 4 жыл бұрын
не видно что пишется на доске, может маркеры тёмные использовать?
@videonafoto
@videonafoto 4 жыл бұрын
Не очень понятно. А как расширять функциональность, если интерфейс менять нельзя? А если клиенту нужны новые методы, или старые методы с другой сигнатурой?
@rusrulet2806
@rusrulet2806 3 жыл бұрын
тоже задался тем же вопросом. и судя по комментам, вопрос остаётся открыт )
@ClydeSimonSound
@ClydeSimonSound 20 күн бұрын
Не понятно, если я добавлю функцию в класс, которая не меняет значения уже существующих полей, это нарушение OCP ?
@vesster2883
@vesster2883 3 жыл бұрын
10:10 Как коротко объяснить разницу между Proxy и Decorator? Поменять выход стрелки. Это самое короткое и понятное объяснение без кода, которое можно использовать в любом коде где это целесообразно. Правда без знания UML понять будет сложно.
@vitalijuskolinko9011
@vitalijuskolinko9011 4 жыл бұрын
Иду смотреть второй раз, чтобы лучше понять ;)
@waltergibbs3041
@waltergibbs3041 Жыл бұрын
а что делать если правки подразумевают под собой дополнение интерфейса?
@konstantinviktorovich8194
@konstantinviktorovich8194 3 жыл бұрын
Поберегите природу, используйте маркерные доски!
@Мария-я3й2в
@Мария-я3й2в 4 жыл бұрын
Добрый день Сергей. Слышали ли Вы о бесплатных курсах Ш++ в Кропивницком, и что о них думаете. Заранее спасибо за ответ.
@LeoMrakobes
@LeoMrakobes 4 жыл бұрын
За Сергея не отвечу, а вот сам я знаком со многими из КОВО где эти курсы проводятся и знаю многих кто после Ш++ достаточно неплохо устроились работать, плюс там отличная внутренняя атмосфера. Если вы сами мотивированны к обучению - то естественно получите хорошие знания
@sergey.stafeev
@sergey.stafeev 4 жыл бұрын
Хорошая скрытая реклама)
@sergey.stafeev
@sergey.stafeev 4 жыл бұрын
@@LeoMrakobes хороший рекламный комментарий)
@Мария-я3й2в
@Мария-я3й2в 4 жыл бұрын
@@LeoMrakobes Понятие "неплохо устроились" у каждого разное, но я все же надеюсь получить ответ от С. Немчинского.
@alexandernifanin7366
@alexandernifanin7366 4 жыл бұрын
Ш++... сколько ассоциаций возникает.
@karabasbarabas2000
@karabasbarabas2000 4 жыл бұрын
Спасибо большое! Шарпистам рекомендую видео от Tim Corey по Solid, чуть длиннее и с примерами
@torrvic1156
@torrvic1156 4 ай бұрын
Да. Тим великий гуру C#. Он больше на практические примеры ориентирован.
@vincentvega1903
@vincentvega1903 4 жыл бұрын
Спасибо
@Bjfhj
@Bjfhj 3 жыл бұрын
Нельзя трогать старый код, а как тогда понять что в родительском модуле есть все необходимые методы для будущего (клиентского) кода ? Или добавление методов в родительский код не будет считаться нарушением OCP, а нарушение будет тогда, когда будут переписываться уже реализованные методы ?
@nrnwest
@nrnwest 2 жыл бұрын
почему не испльзовать абстрактный класс, тот же интерфейс но еще дает плюс
@JackFastGame
@JackFastGame 4 жыл бұрын
Очень важный вопрос: всегда ли следует соблюдать SOLID или есть альтернативные концепции принципов работы в ООП?
@KirillTerekhov
@KirillTerekhov 4 жыл бұрын
JackFastGame есть GRASP как более традиционный набор принципов. Ещё из интересного есть книжка “A philosophy of software design” в который автор подходит к проблеме с другой стороны и даёт определение сложности и поддерживаемости, а из него уже выводятся принципы
@alexandernifanin7366
@alexandernifanin7366 4 жыл бұрын
Точно не всегда. Если проект на десяток тысяч строк, можно смело слать лесом. Сильно ограничивает без особых преимуществ
@JackFastGame
@JackFastGame 4 жыл бұрын
@@alexandernifanin7366 Разве SOLID не помогает в больших проектах?
@alexandernifanin7366
@alexandernifanin7366 4 жыл бұрын
@@JackFastGame Это к чему вопрос? Помогает. Я вообще отвечал на другой вопрос и про небольшой проект.
@dmitryzolkin7904
@dmitryzolkin7904 Жыл бұрын
Подскажите, почему инверсия зависимостей и софт код это не одно и тоже? Разве обращение к конкретным объектам через интерфейс это не софт?
@RadioWestin
@RadioWestin 2 жыл бұрын
совсем неизвестный Бертран Мейер - ничего себе :) автор Eiffel, авторитетной книги ООП "Object-Oriented Software Construction" и еще кучи всего :)
@MegaSosnooley
@MegaSosnooley 4 жыл бұрын
А как быть с MVC? Например у меня есть какой-то контроллер (класс) и что есть добавление методов в него? Изменение класса или расширение класса? Если изменение, то как мне в свой контроллер добавлять методы (экшены) ?
@z1zzz
@z1zzz 4 жыл бұрын
Очень классная линейка видео про SOLID. Большое спасибо вам за это! Если можно, то можете снять также линейку видео про structural, behavioral design patterns. Хотя бы по 3 с каждого?
@ГеоргийОрлов-г5в
@ГеоргийОрлов-г5в 4 жыл бұрын
Сергей, купите пластиковую доску. У меня от скрипа фломастера по бумаге зубы свело! Слушал без звука с субтитрами.
@dmitry_promath
@dmitry_promath 4 жыл бұрын
Такой вопрос: можно ли начать свою карьеру на фрилансе, а уже потом претендовать на позицию middle в it-компании спустя 1-3 года работы на фрилансе? В моем случае именно так получается, тк работаю по контракту и не могу работать официально где-либо еще, плюс ко всему время не позволит. Рассматриваю фронтенд-разработку
@sashchernuh
@sashchernuh 4 жыл бұрын
Сергей, такой вопрос, не знаете ли поменял ли Мейер первое его понимание этого принципа во втором издании в 97 годе, после того как Мартин опубликовал версию OCP в 96 году?
@DenVeR-PRO
@DenVeR-PRO 4 жыл бұрын
Вот это скорость!
@Бензини
@Бензини 4 жыл бұрын
У Вас есть премиум доступ к материалам без менторинга и чата и т.д.? дороговато обцчение)
@sealkeen
@sealkeen 3 жыл бұрын
10:10 Если посмотреть так-то по диаграмме на декторатор, то получается, что у нас циклическая зависимость Прокси от Интерфейса и Интерфейса от прокси) И мы можем вставлять абсолютно любое количество дополнительного функционала: логирование, кэширование, аутентификацию, авторизацию, аудит - поскольку они все полетят в трубу, а проекты просто не скомпилируются :D
@vrabosh
@vrabosh 4 жыл бұрын
А если нашел способ как улучшить старый код, там типа где трогать нельзя, тогда что?
@0imax
@0imax 4 жыл бұрын
Работает - не трогай :) Понадобится "официально" туда залезть - тогда уже можно попробовать внести "новшества".
@vrabosh
@vrabosh 4 жыл бұрын
@@0imax хотя я на начальном этапе максимально стараюсь оптимизировать и гибкость сделать.. и уже когда проект разросья уже не трогать, а все недочеты запоминать на след проект, и потмо уже править в новом проекте.
@LeoMrakobes
@LeoMrakobes 4 жыл бұрын
Историческая отсылка понравилась, а вот по сути - если бы я не знал как работают SOLID принципы - то без наглядных примеров мало что понял бы из этого видео
@alexandernifanin7366
@alexandernifanin7366 4 жыл бұрын
Да, тоже не раз изучал SOLID, но из примеров с нуля точно ничего не понял бы. Хотя, если сделать подробнее, то видео получится на полчаса.
@bashconsole
@bashconsole 3 жыл бұрын
1:12. я вот 20+ лет как программист и тоже выуцчить не могу. странно почему.
@user-hv8rh8nk9d
@user-hv8rh8nk9d 4 жыл бұрын
Вопрос жизни и смерти Когда Сергея Немчинского перестанут звать Сергеем Немчинским?
@vitalik100500q
@vitalik100500q 4 жыл бұрын
Когда замуж выйдет
@gibizov
@gibizov 4 жыл бұрын
Не, а вдруг ещё кто-то не знает? И заметьте, Сергей старается протараторить это как можно быстрее. Хотя уже можно просто рисовать баннер с фио и регалиями, как в программе «Время». 100К уже есть, зачем им слушать это постоянно? Чтоб в подкорку вбивалось? Ну мякше надо, нежнее.
@Oleksii_Leshchenko
@Oleksii_Leshchenko 4 жыл бұрын
@@gibizov Это же фишка про которую столько шутят. Это хорошо Тем более, большой процент новых, не подписанных
@gibizov
@gibizov 4 жыл бұрын
Алексей Лещенко «люблю вас и всё вот это вот» :)
@undefined-n5v
@undefined-n5v 4 жыл бұрын
@@vitalik100500q Возможно тогда появится еще один Сергей Немчинский вполне возможно
@xandrop
@xandrop Жыл бұрын
Все очень хорошо на бумаге, но вот если лектор, чтобы что-то объяснить постоянно лезет в смартфон, то как это ответить на собеседовании, к примеру.
@aaayakou
@aaayakou 4 жыл бұрын
Вопрос: А разве методы расширения не являются примером реализации OCP? Ведь при их реализации мы вроде как не изменяем изначального класса
@levovix
@levovix 4 жыл бұрын
методы расширения это те же методы, но написанные вне класса. никаким примером они не являются
@aaayakou
@aaayakou 4 жыл бұрын
@@levovix ок, ясно
@Tolgetmen_dev
@Tolgetmen_dev 4 жыл бұрын
Ля как маркер крутит)
@user-888azim-97
@user-888azim-97 3 жыл бұрын
😂
@undefined-n5v
@undefined-n5v 4 жыл бұрын
Так, ничего не понял. А разве зависимость от интерфейсом не относится к Dependency Inversion Principle?
@SergeyNemchinskiy
@SergeyNemchinskiy 4 жыл бұрын
все принципы связаны. но да. это именно к тому принципу. Просто я пояснил и дополнил, чтобы у людей было связанное понимание принципов
@vitaliyprokopov2194
@vitaliyprokopov2194 4 жыл бұрын
Сергей, Бертран Маер также придумал язык Eiffel, который по-сути есть примером подхода программирования по контракту)
@DrZupan
@DrZupan 2 жыл бұрын
что отвечать на собеседовании на вопрос "что такое О с солид?" так и не понял)
@DanyaIzyum
@DanyaIzyum 6 ай бұрын
dont cahch this - может я что-то не знаю но в Python нет интерфесов получается что нужно создавать абстрактные классы для того чтобы их имплементировать другими классами - но если в других языках понятно что он имплементирует то для классов вообще не очень понятно, почему нельзя делать decorator функции если она чем -то не подходит, хотя конечно это уже будет другая функция и работать она может по другому. с точки зрение истинного полиморфизма это не пойдет, зато дублирования кода никакого не будет.
@СергейКондратенко-о9ц
@СергейКондратенко-о9ц 4 жыл бұрын
Благодарю за видео, только не очень понятно, как ваша установка о том. что работающему программисту не нужно прокачивать т. н. хардскиллы в свободное от работы время, увязывается с тем, что вы преподаете курс по паттернам явно не для новичков
@Enterprise_IT_support
@Enterprise_IT_support 2 жыл бұрын
👍
@cyrilanisimov
@cyrilanisimov 4 жыл бұрын
Мы тоже тебя любим)
@NummeSpnet
@NummeSpnet 3 жыл бұрын
получается OCP от Дяди Боба есть ни что иное как DIP... получается O зависит от D )
@MaksUsanin
@MaksUsanin 4 жыл бұрын
"все ещё зовут Сергей Немчинский" :))
@anzarsh
@anzarsh 3 жыл бұрын
Захардкожено)
@apdgslfhsodbna
@apdgslfhsodbna 4 жыл бұрын
Работал в 2х компаниях дот нет джуном... омг сколь там было говна, платили хорошо, но видимо понимали что с этим легаси разбираться, и одна из этих компаний достаточно известная.
@homo-ergaster
@homo-ergaster 4 жыл бұрын
Не Microsoft случаем? У меня университетский товарищь ушел к ним. Говорит класс на 50 тысяч строк запилить там как запросто.
@apdgslfhsodbna
@apdgslfhsodbna 4 жыл бұрын
@@homo-ergaster , яндекс
@UGEEGO
@UGEEGO 3 жыл бұрын
В названии не закрыты круглые скобки ;)
@victormakovchik249
@victormakovchik249 3 жыл бұрын
Кроме Бертрана Мейера был ещё Сид Мейер - разработчик культовой игры Цивилизация! Может родственник?)))
@TheDEFCHER
@TheDEFCHER 3 жыл бұрын
Так много людей которым нравиться видос и которые ничего не поняли. Я так и не понял что это на практике, даже нет никакого вывода с чёткой формулировкой что это такое. Мне просто использовать интерфейсы и работать через них или что?
@RusIvan2022
@RusIvan2022 2 жыл бұрын
Да если патерны посмотреть, тоже все сходится к использовании интерфейсов. А вообще все принцепы и патерны сводятся к тому что нужно делать так чтоб ты мог дописывать код и ничего не ломалось.
@lukeskyworker2637
@lukeskyworker2637 4 жыл бұрын
В учебниках для начинающих всё время пишут о Полиморфизме, Инкапсуляции и Наследовании. Но, не поясняют по-нормальному, для чего это нужно. На живых примерах. Т.е. наследование нужно, как я понял из этого видео, что бы, в том числе и не добавлять баги в уже работающий код. И что бы не тратить деньги на тестировщиков, которые эти баги будут отлавливать.
@alexandernifanin7366
@alexandernifanin7366 4 жыл бұрын
ООП был изобретён намного раньше SOLID. Согласен, принцип подходит для наследования, только наследование не обязано подчиняться OCP. Есть класс „насекомое“. К нему добавляются методы „ползать“, „летать “, „жалить“. От него можно наследовать жука, гусеницу, осу. Тратить деньги на тестирование всё равно придётся, просто меньшие.
@son9261
@son9261 4 жыл бұрын
Кайфонул)
@Макс523
@Макс523 3 жыл бұрын
Ok!
@crypto_octocat
@crypto_octocat 4 жыл бұрын
Черные футболки дают +10 к солидности )
@hpw-dev
@hpw-dev 2 жыл бұрын
я смотрю в 1080p и не вижу чё на доске, это всё равно что писать ярко жёлтым по белому
@brodlovherrsov7097
@brodlovherrsov7097 4 жыл бұрын
А че ты подглядываешь?)
@Maxlyaptsev
@Maxlyaptsev 3 жыл бұрын
Зачем же вы бумагу переводите. Доску специально делают такую чтобы можно было легко стереть каракули. Куда эта бумага потом попадает? На полигоны и складируется? На ней еще ничего и не видно, и скрип неприятный. Откуда вы такие беретесь то, вроде видео 2020 года
@Alexey0795
@Alexey0795 4 жыл бұрын
8:35 "листочек"
@Sasha2dx
@Sasha2dx 3 жыл бұрын
Я если что могу серъёзно заниматься разработкой даже выписывая перманентный говнокот. :D
人是不能做到吗?#火影忍者 #家人  #佐助
00:20
火影忍者一家
Рет қаралды 20 МЛН
Cheerleader Transformation That Left Everyone Speechless! #shorts
00:27
Fabiosa Best Lifehacks
Рет қаралды 16 МЛН
Product Owner vs. Product Manager
4:56
Ilia Pavlichenko
Рет қаралды 2,9 М.
Принцип хорошего кода YAGNI ("You aren't gonna need it")
15:08
Почему нельзя возвращать NULL?
22:11
Sergey Nemchinskiy
Рет қаралды 117 М.