Принцип подстановки Барбары Лисков - SOLID в деталях

แชร์
ฝัง
  • เผยแพร่เมื่อ 27 ม.ค. 2025

ความคิดเห็น • 19

  • @shurik_codes
    @shurik_codes  ปีที่แล้ว +1

    Вступайте в официальный паблик в VK: vk.com/shurik_kodit
    Подписывайтесь на канал в Telegram: t.me/rural_java

  • @Сергей-БСД
    @Сергей-БСД 3 หลายเดือนก่อน +1

    Круто! Спасибо!

  • @Antimurr
    @Antimurr 6 หลายเดือนก่อน +1

    впервые встречаю того, кто четко объясняет этот принцип с использованием ковариантности и контрвариантности, а не как обычно невнятно чего-то там про "соблюдайте контракт" - а что оно такое даже и не говорят в итоге
    однозначно зачет

  • @TheGwenIngwarr
    @TheGwenIngwarr ปีที่แล้ว +2

    После вашего объяснения все встало на места с этим принципом, спасибо

  • @T_Sub4ik
    @T_Sub4ik 2 หลายเดือนก่อน +1

    спасибо!

  • @andd3dfx
    @andd3dfx 3 หลายเดือนก่อน +1

    Благодарю за видео, но:
    - Термины ковариантность/контравариантность - хорошо бы определить вслух, что они значат, до многократного их использования.
    - Пару раз наблюдался паттерн: код/тест написали, запустили - он прошел, потом ("ой, да - тут надо по другому") поправили - и НЕ запустили. А вдруг теперь не пройдет тест?

  • @dmitrylemeshenko9642
    @dmitrylemeshenko9642 ปีที่แล้ว +1

    Спасибо!!!!!

  • @romanovichihin2429
    @romanovichihin2429 ปีที่แล้ว +2

    Лайк, коммент, следующий ролик!

  • @shurik_codes
    @shurik_codes  ปีที่แล้ว +2

    Записал вдогонку ролик с решением проблемы квадрата/прямоугольника: th-cam.com/video/AILeiAJY_78/w-d-xo.html

  • @alexeysvetlenko2217
    @alexeysvetlenko2217 ปีที่แล้ว +5

    Тему Ковариантности/Контрвариантности раскркрой более широко пожалуйста. Класно бы в сравнении с TypeScript.

    • @Muchitel
      @Muchitel ปีที่แล้ว

      поддерживаю. Не совсем понятно как мы от упрощеной трактовки принципа перешли к ограничениям на Ковариантности/Контрвариантности :)

  • @shluhogon_42
    @shluhogon_42 ปีที่แล้ว +5

    Так в конце нужно было показать, как правильно орагнизовать логику класса

    • @shurik_codes
      @shurik_codes  ปีที่แล้ว +2

      Да, хорошее замечание, надо было сделать какой-то вывод. Но конкретно проблема квадрат/прямоугольник решается отделением Square от Rectangle в силу того, что логика изменения размеров у них принципиально отличается.

    • @shluhogon_42
      @shluhogon_42 ปีที่แล้ว

      @@shurik_codes в принципе можно вынести метод в интерфейс или абстрактной фигурой пользоваться.

    • @shurik_codes
      @shurik_codes  ปีที่แล้ว +1

      Это не решает проблемы, так как чтобы определить ожидаемое поведение (в данном случае вычисление площади), нужно знать, с экземпляром какого конкретно класса взаимодействует код. В продемонстрированном коде теста эта проблема не совсем очевидна в силу того, что экземпляр тестируемого класса создаётся прямо в тестовом методе. А вот если бы экземпляр класса Rectangle получался от абстрактной фабрики или фабричного метода, то тогда пример был бы нагляднее: мы получаем прямоугольник, устанавливаем размеры 10х3, и ожидаем площадь 30, но получаем - 9.
      Да и в целом вынос метода в интерфейс или абстрактный класс не решит нарушение принципа, заключающееся в изменении свойств родительского класса в методе класса-наследника. Тут до кучи проявляется нарушение принципа открытости/закрытости.

  • @scc-6
    @scc-6 8 หลายเดือนก่อน +1

    Если рабоотает с классом, то должно работать и с подклассом этого класса. Нужно запомнить, что это именно L в солид, спасибо

  • @sergeyklunniy8839
    @sergeyklunniy8839 10 หลายเดือนก่อน

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

    • @shurik_codes
      @shurik_codes  10 หลายเดือนก่อน

      Возможно, я не совсем ясно выразился в ролике, отрицать не буду. Но ковариантность и контравариантность типов аргументов при переопределении методов в Java не работают.
      Да, можно в классе-наследнике объявить метод с сигнатурой, отличающейся только типом аргумента от сигнатуры метода из класса-родителя, проблем с точки зрения компилятора это не вызовет. Но это будет уже не переопределением метода (overriding), а перегрузкой (overloading). И это будет уже новый, а не наследуемый метод.

  • @donpedro2125
    @donpedro2125 9 หลายเดือนก่อน +3

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