Избавляемся от If и Switch в коде на C#! КАК !?

  Рет қаралды 98,182

Роман Сакутин

Роман Сакутин

Күн бұрын

Пікірлер: 171
@slava6105
@slava6105 3 жыл бұрын
8:23 class Damageable c# naming conventions: имена классов должны быть существительными (noun) из 1 или нескольких слов (noun phrases), имена интерфейсов должны быть (фразами) существительными (noun) или прилагательными (adjective).
@theshamil6796
@theshamil6796 2 жыл бұрын
А где вы эти все правила наименования берете? Можете скинуть такие сайты. Я мучаюсь с тем, как следует называть делегаты и события, а также методы, которые мы в них передаем. Вроде такое правило специальное есть.
@boost_456
@boost_456 8 ай бұрын
@@theshamil6796 официальный сайт Майкрософт, C# specification. Они же и создали этот ЯП
@oneprogofficial
@oneprogofficial 4 ай бұрын
@@theshamil6796 в доках c#
@AnastasiaPilipchuk-o5y
@AnastasiaPilipchuk-o5y 3 ай бұрын
Codestyle ​@@theshamil6796
@axsuam
@axsuam 5 жыл бұрын
Немного изменил мой процедурноориентированный мозг.
@aDahur
@aDahur 2 жыл бұрын
«Вот так, с помощью нехитрых приспособлений буханку белого (или черного) хлеба можно превратить в троллейбус… Но зачем?»
@samgot100
@samgot100 5 жыл бұрын
Чувак. Работай над звуком! Хороший контент погибнет потому, что много людей его просто не услышат.
@zORg_alex
@zORg_alex 4 жыл бұрын
Хотел спросить, нельзя ли потише, а то ещё слышно.
@JackFastGame
@JackFastGame 4 жыл бұрын
Ещё с произношением английского беда.
@ЕвгенДи
@ЕвгенДи 4 жыл бұрын
+1 годный контент, но приходиться на макс выкручивать громкость.
@DarkW1zard
@DarkW1zard 3 жыл бұрын
думаешь легко вот так сразу вовремя микрофон из ж**пы вытащить. :)
@MarloGrayhat
@MarloGrayhat 3 жыл бұрын
Согласен, очень трудно слушать, прям до зевоты.
@hematogen50g
@hematogen50g 3 жыл бұрын
Предусматривать ситуации, которые "никогда не произойдут" это очень круто.
@101picofarad
@101picofarad 2 жыл бұрын
Это называется определять множество функции на множестве аргументов, которые не планируется использовать.
@МаксимМалышев-м6ы
@МаксимМалышев-м6ы 4 жыл бұрын
А разве это не паттерн стратегия ? Здесь же замену объекта контролирует клиент, а в паттерне состояние это делает либо контекст, либо само состояние имеющее ссылку на контекст, без участия клиента. Да и чисто семантически, вы устанавливаете СТРАТЕГИЮ (то есть алгоритм) расчета урона в зависимости от типа юнита, а не от его состояния (что юнит ранен/устал/болен и.тд)
@eugenekrutoy1475
@eugenekrutoy1475 4 жыл бұрын
Вопрос, чем таки плох switch? Ведь в первом примере, закинул на кучу три экземпляра, а если их больше и они сложнее это работа для garbage collector.
@MultiGameAD
@MultiGameAD 3 жыл бұрын
Потому что про память никто не будет думать, когда вопрос стоит про архитектуру приложения. Байтоёберство мешает разработке сложных систем а к этим приёмам нужно привыкать в самом начале, как к хорошему тону.
@antonpashkevich5061
@antonpashkevich5061 2 жыл бұрын
Так он же сказал чем плох switch, при расширений придется каждый раз добавлять case. А зачем? Это писанина , когда можем в классе одну строчку добавить место целого case.
@eugenekrutoy1475
@eugenekrutoy1475 2 жыл бұрын
@@antonpashkevich5061 Я бы по дискутировал, но нужно пересмотреть видео, что бы понять, о чем речь, комент писал год назад🙂, но судя по коментарию, дело не в том, что проще написать, а в производительности. Наверное меня смущала лишняя работа сборщика.
@cheefoxcheefox2372
@cheefoxcheefox2372 2 жыл бұрын
По поводу вопроса "визуализация сущности - это не задача самой сущности" можно попробовать передать ответственность в Какой-нибудь Printer, который будет форматировать данные сущности. И этот принтер передавать в метод show для сущности. Так мы выделим из неё этот responsibility
@АлександрРогов-я1й
@АлександрРогов-я1й 6 жыл бұрын
Привет. Спасибо за видео. Было бы интересно посмотреть материал про паттерн "Состояние".
@theMRbot2013
@theMRbot2013 3 жыл бұрын
"Кода стало больше, он стал лучше." Нет, не стал, мы опять обменяли память на быстродействие.
@narilcrow
@narilcrow 3 жыл бұрын
я только начал учить язык вопрос? . а если свитч будет допустим 100 кейсов то что лучше ?
@theMRbot2013
@theMRbot2013 3 жыл бұрын
@@narilcrow свитч и создан для множественного выбора. Либо свич, либо миллион реализаций, как в видео. Но настолько большой свич, может свидетельствовать о неправильном подходе при разработке алгоритма. Опишите подробнее ситуацию, может быть предложу альтернативу.
@narilcrow
@narilcrow 3 жыл бұрын
@@theMRbot2013 нет у меня свитчей на 100 кейсов просто вопрос . это мысленный эксперимент не более .
@theMRbot2013
@theMRbot2013 3 жыл бұрын
@@narilcrow тогда на чисто риторический вопрос чисто риторический ответ: ошибка в разработке алгоритма.
@narilcrow
@narilcrow 3 жыл бұрын
@@theMRbot2013 спс за ответы .
@febman7495
@febman7495 4 жыл бұрын
Нормализации звука - наше все, чел!
@markd8593
@markd8593 4 жыл бұрын
как включить вертикальные пунктирчики для фигурных скобок?
@userAS456
@userAS456 3 жыл бұрын
Что-то с Damageable тут явно дичь какая-то... Опять же куча копипасты в коде остается и наследование от класса, который не является образующим для сущности. Я, конечно, не особо шарю про игрострой, но разве плохо интерфейсы для таких вещей использовать и проверять возможность урона по наличию онного через where метода или каким-нибудь гетом из движка? Я понимаю, что конкретно в этом случае может так приемлимо и даже хорошо, но очень хочется разобраться в целом.
@kirillsviderski4739
@kirillsviderski4739 6 жыл бұрын
а вот со второй штукой хочется поспорить. порой реально удобнее использовать свитч, оставив наследование на как можно более поздний уровень (непосредственно работа с префабами/блюпринтами)
@rsakutin
@rsakutin 6 жыл бұрын
Я не совсем понимаю о чём идёт речь. Можете привести пример?
@kirillsviderski4739
@kirillsviderski4739 6 жыл бұрын
Юнити касается в меньшей мере, в префабы не наследуются, ближе подход к анриалу. Допустим есть ряд объектов, которые невероятно похожи (к примеру оружие в игре, или гранаты. или какие-то странные машинки с очень спецефическими нюансами в управлении), которые отличаются реально в одной мелочи (читай, в одном методе) тогда, для дизайнеров и прочих удобнее если им нужно будет брать не один из кучи компонентов вида "фигня 1", "фигня 2", "фигня редкая баклажанная", а просто выбрать из выпадающего списка его тип таким же способом удобно сделать всякие "способности" в играх, если их набор заранее очерчен и конкретные способности отличаются лишь анимациями и значениями маны/урона. Ты даёшь геймдизам конструктор из которого он собирает очередное гавно, которая сломает баланс игры :)
@rsakutin
@rsakutin 6 жыл бұрын
У нас примерно так и сделано кстати. Только вместо перечислений используем выпадающий список из реализаций интерфейса - sun9-9.userapi.com/c840731/v840731632/5ff3f/T_BDmPITWF8.jpg
@крл-я1щ
@крл-я1щ 6 жыл бұрын
Благодарю, очень интересные способы, которые, на самом деле, делают код красивым)
@СлаваМикуть
@СлаваМикуть 4 жыл бұрын
Прощу прощения, а можете скинуть методички, про которые говорите в видео?
@utka7066
@utka7066 4 жыл бұрын
хе-хе, про такую реализацию логики знал, про такое как в принимаемых consolecolor color не знал, спасибо за видео.
@melnorme777
@melnorme777 4 жыл бұрын
Во 2м примере вспоминается warcraft 3, там похожая ситуация - юниты получают разное количество урона в зависимости от типа брони, но там все-таки сложнее, т.к. тип атаки тоже разный. Здесь можно обойтись 1 классом Unit, сделать у него поле damageMultiplier и в ApplyDamage() сделать Health -= damage * damageMultiplier
@tavernaan
@tavernaan 4 жыл бұрын
Вообще можно, но он для примера показал что делать если нужно исполнить разный код в зависимости от того, кто попал под урон
@Sennken
@Sennken 4 жыл бұрын
Нихуя ты умный. Я б тебя назначил главным программистом.
@alquemir
@alquemir 4 жыл бұрын
Лучше использовать Dictionary чем Array, потому что у тебя нет гарантии "itemId" всегда будет последовательным
@dick4334
@dick4334 2 жыл бұрын
что за сочетания клавиш на 5ой минуте?
@АндрейБурачковский-й1з
@АндрейБурачковский-й1з 4 жыл бұрын
Будьте осторожны и внимательны с копипастой. Автор видео хорошо продемонстрировал возможный выстрел себе в ногу. В первом примере до рефактора последовательность цветов была "красный, синий, серый", после рефактора стало "Синий, красный, желтый".
@iliyabogomya5203
@iliyabogomya5203 4 жыл бұрын
суть же не цветах, а в способах реализации
@djekil.henryyy
@djekil.henryyy 4 жыл бұрын
😂
@ievgenk.8991
@ievgenk.8991 4 жыл бұрын
С одной стороны сущность сама себя отрисовать не может, с другой стороны сущность сама себе нанести урон может. Увеличивается объем кода, добавляется абстракции, выстраиваются новые цепочки наследования и всё ради того что бы избавиться от if-else? Чем же эта конструкция так ужасна? Боюсь представить что будет если новичок будет пытаться строить нечто похожее.
@darkproject8068
@darkproject8068 2 жыл бұрын
Тем что она часто упирается в производительность. Если ты люто обмазываешься тактами и операциями в с, то неожиданно для себя откроешь, что полиморфизм быстрее условий раза так в 2. Я писал компилятор, и разница когда ты делаешь всё через различные условия и полиморфизм очень даже ощутимая. Диск ~80мс + сборка 25\10мс. (+Так легче код поддерживать)
@valentinegorov7720
@valentinegorov7720 4 жыл бұрын
Примеры хорошие. Только в первом примере другие компоненты не знают по какому индексу с массиве лежит item, и где-то снова возникнет хардкод индексов. С точки зрения самого примера это не критично, но ведь кто-то этого не поймет и так и напишет. Второй пример хочется расширить до разрушаемых и не разрушаемых объектов (например зданий), потому что новички просто все унаследуют от Damageable с пустым ApplyDamage
@wladyslaw1174
@wladyslaw1174 2 жыл бұрын
Я думаю, что будет лучше поместить все в интерфейс, а для зданий добавить еще один интерфейс для разрушения
@f1lih587
@f1lih587 6 жыл бұрын
Очень интересная тема, продолжай)
@Houlser
@Houlser 2 жыл бұрын
Нащет замены switch хороши сделано сделал код удобней и легко редактируемым спасибо Роман
@Pepper-y4g
@Pepper-y4g 6 ай бұрын
А в чем проблема сделать все не через класс item, а через hashSet
@senioreasy
@senioreasy 4 жыл бұрын
Есть минус у твоего рефакторинга: дополнительное выделение памяти. Под создание массива в 1 случае, и создание виртуальной таблицы во 2м. Для 1 случая сам процесс выделения памяти относительно дорогой, и им не стоит злоупотреблять. 2й способ очень хорош, если много вариантов в изначальном switch
@SysWOOOW
@SysWOOOW 4 жыл бұрын
Смысл вообще твоей претензии, когда в массиве 5 элементов всего? Пишешь как тебе удобнее. Главное читаемость и реюзабилити кода, расширяемость
@senioreasy
@senioreasy 4 жыл бұрын
@@SysWOOOW Отвечу на твой пост, чисто ради продвижения этого видео чуть выше в топ :) В моём 1м посте констатация факта. Память выделяется. Каждый сам решает для себя, как ему и что удобней. В принятии решения нужно учитывать все плюсы и минусы.
@СеняАшлапов
@СеняАшлапов 3 жыл бұрын
Как по мне, любая претензия в плане "доп затраты для памяти" неуместны, в частности для unity и c# в связке. На это есть несколько причин: 1)в c# нет достаточного количества инструментов для динамической работы с памятью, как в c или c++. Хитровыебнуться с динамическим выделением памяти(и конечно же с динамической чисткой) под объект, имеющем в себе трехмерные массивы не выйдет, сдвинуть побитово массив из указателей тоже (да и не надо, не для этого язык создавался). На борту c# уже есть "авточистка", которая +- нормально работает. Можно запариться и написать библиотеку на чистом с, которая будет подчищать память в процессе работы, но это такой гемор, который ещё мир не видовал 2) unity не самая оптимизированная платформа, которая сама по себе работает так себе. И игры, которые выходят с её конвейера даже с самым оптимизированным кодом (if и switch повсюду лол) работают жопой об косяк(вспомним Тарков), только если это не супер казуал, где нечему нагружаться . Пример в видео не нацелен на оптимизацию, видео вообще не про это(кста, вроде такое видео есть на канале), это про то, как сделать код более логичным, архитектуру устойчивой и удобное взаимодействие с кодом в будущем. Можно написать код один раз так, чтобы он работал и ты даже вроде понимаешь, как она работает, как все устроено, но в какой-то момент тебе надо его дополнить или исправить...и ты даже не знаешь, как к нему подступиться, потому что код хоть и логичен, но не структурирован.
@senioreasy
@senioreasy 3 жыл бұрын
@@СеняАшлапов я пишу на плюсах, и делаю с памятью что хочу 🙈 Могу массив структур и на стеке разместить (если прям часто используется) Часто используемый код оптимизируешь с профилировщиком и красота. Про выделение памяти в С# с тобой согласен.
@dgonicoks1775
@dgonicoks1775 4 жыл бұрын
Ублюдские костыли! Все глаза в начале сломал, ну нахрена??
@viktortihobrodvey7149
@viktortihobrodvey7149 4 жыл бұрын
сними еще видео,как говорить,чтоб тебя все хорошо слышали)
@andzri
@andzri 4 жыл бұрын
Во второй ситуации, вроде, можно было сделать класс для объектов (Human, Animal, Building). И просто задавать им параметры.
@mezozzoi
@mezozzoi 4 жыл бұрын
Ну это так, для наглядности полиморфизма создал. С точки зрения программирования(не с точки зрения темы этого видео) это является правильным кодом. Можно так же переименовать Damageable в Entity, чтобы было более "правильно"
@andzri
@andzri 4 жыл бұрын
@@mezozzoi Ну ок, спасибо за ответ.
@IlyaMoss
@IlyaMoss 4 жыл бұрын
Деда с костылями на фоне - я снимал, так уж вышло)
@ProkerKusaka
@ProkerKusaka 4 жыл бұрын
Компот тренируется к следующей битве
@anagr_
@anagr_ 4 жыл бұрын
Отличное содержание, НО ... буквы и картинки с эффектом зумИн/зумАут постоянными и тихий звук оооочень напрягают. Лови палец вверх :)
@w.t.2905
@w.t.2905 2 жыл бұрын
Ждём ролик, когда будешь код для прода писать
@STARasGAMES
@STARasGAMES 6 жыл бұрын
давай ищчо! про состояния интересно послушать. Насчёт второго примера, думаю что для геймдева ни перечисление ни наследование не подходят. Если говорить про юнити, то она компонент-ориентирована, поэтому стоит это использовать для добавления свойств. Для каждого свойства отдельный компонент. И использовать префабы вместо скриптабл обджектов. В реальном проекте такой метод не пробовал, просто пища для размышлений. Просто наследование и другие методики - это программирование "в слепую", без интерфейса. В случает движка это не эффективно. Вот что я хотел сказать. Видео классное, и оно подойдёт для изучения C#, но вот для геймдева не слишком применимо. Точнее не в этом направлении нужно обучать(возможно) И вообще, на программиста слишком много навешивают, а как же дизайнеры?)
@rsakutin
@rsakutin 6 жыл бұрын
Наследование везде не любят, на только в GameDev :)
@kirillsviderski4739
@kirillsviderski4739 6 жыл бұрын
парень, с помощью перечислений ИИ для уловной мобы может написать школьник за часик. при чём безопасно в плане механических описок. если Ты считаешь перечисления чем-то не нужным - просто начни писать что-то большее, чем базовые туториалы. для написания игровой логики они оч важны и удобны
@STARasGAMES
@STARasGAMES 6 жыл бұрын
Если ты делаешь игры в соло, то здесь тебя никто не ограничивает - делай что хочешь. Если дело доходит до командной работы с дизайнерами, которые не шарят твои программные "приколы", то начинаются проблемы. Да и проблема в том, что всех изначально приучают использовать перечисления и наследование, ведь это действительно удобно для небольшого туториала. Ну а вот туториалов по тому, как организовать сложный и большой проект я не видел пока что. Ведь это не выгодно создателю видео.
@kirillsviderski4739
@kirillsviderski4739 6 жыл бұрын
так дизайнерам даёшь готовый функционал. лучше вообще у них студию удалить и заблочить запуск моно ;) наш проект делает пол сотни людей, весит он добрых 130 Гб, и я просто понятия не имею как без перечислений можно поднять такую махину. перечисления лежат в основе FSM. Альтернатива перечислениям тут только старые олдскульные сишные дефайны, но это реально опасная штука
@STARasGAMES
@STARasGAMES 6 жыл бұрын
kirill sviderski а а а Ты меня не понял) Я не против перечислений и наследования это основы! Куда без них?) Это как отказаться от функций и возвращать значения через параметры метода. Но в примере, показанном в видео, можно найти более красивое и юзер френдли решение
@Oleksandp
@Oleksandp 3 жыл бұрын
Надеюсь вы таки узнали о существовании Dictionary...
@cheefoxcheefox2372
@cheefoxcheefox2372 2 жыл бұрын
Во втором примере стоит оговорить, что это не совсем разные алгоритмы, а алгоритмы из какого-то класса, что мы можем выделить обобщённый алгоритм по зависимости. Если бы речь шла, скажем, о типах сообщений от операционной системы, то там просто входящий параметры могут оказаться разными: либо координаты, либо код клавиши, например.
@igorbakulin
@igorbakulin 6 жыл бұрын
Роман, а кроме красивого кода, есть ли выигрыш в производительности?
@rsakutin
@rsakutin 6 жыл бұрын
А кому она нужна, производительность? Быстрей ифов ничего работать не будет. Полиморфизм съедает много ресурсов, и кое-где его применение вообще запрещено. Например VK отказались от ООП в PHP как раз отчасти из-за этого.
@vladk4144
@vladk4144 5 жыл бұрын
@@rsakutin а тогда какой смысл в том, что ты сделал? Выходит ты просто увеличил количество кода без надобности и усложнил читаемость.
@adiks09
@adiks09 4 жыл бұрын
@@vladk4144 смысл в расширяемости я тоже думал нахера оно это пока мне не понадобилась сделать больше персонажей чем один, а если у тебя их 200 и более, поэтому это важная и прикольная штука
@tavernaan
@tavernaan 4 жыл бұрын
@@vladk4144 как по мне гораздо понятней стало
@MrDlop
@MrDlop 3 жыл бұрын
А не проще было текст выводить с переменной, А цвет ставить через массив или enum.
@miefis
@miefis 5 ай бұрын
Сакутин пишет через камтазию Моё уважение Но у меня это был единственный вариант (только камтазия 8 работала на виндоус икспи)
@R0MaNbI4-
@R0MaNbI4- 3 жыл бұрын
Начало 1:39
@darkproject8068
@darkproject8068 2 жыл бұрын
Найс ты меня просветил. Для челов который дрочат на оптимизон, говорю - Виртуальные методы это таблица, а ифы и кейсы 95% это условные ветвления. По таблице ты просто перешёл и потратил х2 такта, а условие хоть и обрабатывается х1 но полностью ломает конвейер процессора и в итоге ты получаешь шляпу.
@artiomciobanu4689
@artiomciobanu4689 4 жыл бұрын
ShowInfo можно ещё сделать extention-методом
@MrGallus
@MrGallus 2 жыл бұрын
В первой ситуации я бы использовал цикл и массив цветов, меньше кода вышло бы.
@BatonyRobson
@BatonyRobson 3 жыл бұрын
нормализуйте звук плиз, еду в тралике, на полной громкости еле-еле слышу
@smipealex3173
@smipealex3173 2 жыл бұрын
Надо использовать goto, if else, switch для лохов))))
@baddotnet
@baddotnet 2 жыл бұрын
я бы вообще убрал items и использовал tuple, еще больше сокращаем код, так сказать
@ВалерийЛысенко-н7к
@ВалерийЛысенко-н7к 6 жыл бұрын
Спасибо. Уже применил)
@padla6304
@padla6304 Жыл бұрын
ничё не понятно Рома себе под нос пробормотал а ты разберись)))
@АндрейЧулков-л2с
@АндрейЧулков-л2с 4 жыл бұрын
Спасибо! Классно!)
@CrafterMinecrafter
@CrafterMinecrafter 4 жыл бұрын
если операций много и код повторяется 1400 раз, static и массивы лучше не юзать.
@mezozzoi
@mezozzoi 4 жыл бұрын
Массивы(с фиксированным кол-во) это узконаправленная фича. ArrayList топ
@yorikde
@yorikde 4 жыл бұрын
@@mezozzoi ArrayList давно устарел, вместо него используют List
@secondlife8138
@secondlife8138 4 жыл бұрын
Ужасная заставка в начала ролика, хотелось выключить просто из-за того, что кровь из глаз пошла. Используй статичные картинки или гифки с большей длинной пожалуйста.
@cppmake7702
@cppmake7702 4 жыл бұрын
1 случай: афтар, плохому детей учишь, уж лучше пускай юзают свич, чем массив классов, которые жрут память, да и к томуже будут пораждать промахи кеша в критичных к скоростям участкам. В таких случаях либо массив стековых данных, либо свич, иначе стремление к красоте породит фризы на этапе продакшна, а ведь можно избежать этого сразу
@rsakutin
@rsakutin 4 жыл бұрын
Какой же мусор у вас в голове :)
@Brick87Game87
@Brick87Game87 4 жыл бұрын
главное чтобы код удобно читался
@Алексей-ы3ы6ю
@Алексей-ы3ы6ю Жыл бұрын
Выключили спустя 2 минуты из за деда с костылями и кучи воды ниочем
@enrewardronkhall8340
@enrewardronkhall8340 4 жыл бұрын
Голова закружилась от гифки
@MrJavaNinja
@MrJavaNinja 3 жыл бұрын
нда. может пример фиговый или еще что, но ИМХО стало хуже. зачем-то создали класс там где спокойно обходились без него
@igorcoolman
@igorcoolman 6 жыл бұрын
ага избавились от свич, но нагородили кучу непонятного кода, да еще и массив создали , супер.
@rsakutin
@rsakutin 6 жыл бұрын
Игорь Князь в чем проблема массива если он скрывает индексацию малой ценой (память на ссылки на объект почти не расходуется). Также код понятен любому мало мальски образованному программисту.
@АлександрБычко-п9ъ
@АлександрБычко-п9ъ 5 жыл бұрын
Самое главное это удобство редактирования кода и всегда надо это учитывать. Что бы внесение изменений не вызывало головную боль и трату кучи времени.
@user-ffffffff
@user-ffffffff 2 жыл бұрын
@@rsakutin тем что id это уникальный идентификатор. Понадобиться из игры удалить пару items из середины и все приплыли, переписывай потом за тобой и указывай id для пару сотен накопившихся вещей.
@slavatar1337
@slavatar1337 3 жыл бұрын
Тогда можно было и в ShowDataInfo(d, c) передавать ссылку на объект и все. Вообще, хотелось бы больше узнать про техническую часть - мне кажется что создание массива, класса это будет более затратно по ресурсам чем самый первый метод
@slavatar1337
@slavatar1337 3 жыл бұрын
ниxyя, не досмотрел 10 секунд и там показали что так и сделали. Ну тогда да - так намного лучше будет
@markow5062
@markow5062 3 жыл бұрын
Шутки не очень, информация очень полезная, но чел, не нужно выкрикивать, режет уши, из-за того, что выкручиваю на максимум.
@ostrov11
@ostrov11 4 жыл бұрын
...чувак ты путаешь СИНТАКСИС и КОД
@olegpaycat4503
@olegpaycat4503 4 жыл бұрын
тише можно?
@tomasgammister5776
@tomasgammister5776 5 жыл бұрын
я конечно только учусь, но как по мне, это просто выпендреж . больше запутал ,чем научил
@iKolesDev
@iKolesDev 5 жыл бұрын
Это кажется выпендрёжем до первого серьёзного, расширяемого проекта. Когда на двухсотом case'е ты перестанешь понимать что ты делаешь, а при желании что-либо поправить - убьёшь несколько часов на ctrl+c и ctrl+v. Это как ездить на велосипеде. Он охуенен, пока ты двигаешься на нём от дома до ларька с сигаретами, а когда нужно перевезти 10 тонн кирпичей для дома - начинаешь понимать, что где-то ты проебался в своём выборе способа передвижения
@tomasgammister5776
@tomasgammister5776 3 жыл бұрын
@@iKolesDev прошел год и теперь я понимаю о чем видео, так как сам недавно не зная о том, реализовал без апдейта подобную систему с уроном, учетом брони и смертью противника. время "лечит" как говорится. только сейчас начинаю понимать эти маневры, так как опыта на тот момент не хватало понять. так что за комент стыдно теперь. )))
@user-ffffffff
@user-ffffffff 2 жыл бұрын
Интерфейсы для лохов, давай абстрактные классы!
@dimaan29
@dimaan29 4 жыл бұрын
Ну избавились вы от условных ветвлений, на что похож стал ваш код, на шифрограмму и по объёму такой же длины. Код должен быть читаемым для всех программистов. Вы б ещё на ассемблере написали такую простую задачу как ветвления. Зачем усложнять жизнь.
@Androix77
@Androix77 4 жыл бұрын
В данном случае изменения были не ради читаемости. Проблем с читаемостью у свитча особо нет. Все было сделано ради большей расширяемости.
@stanislavsh6582
@stanislavsh6582 4 жыл бұрын
Ну фиг знает. Как по мне как раз читать это легче. А А про читаемый для всех программистов. Все кто изучали ООП это без проблем прочитают, а если человек заявляет что он программист шарпов, он по-умолачанию должен ООП изучить был. Про зачем усложнять жизнь. Конечно, если пишется что-то маленькое, тем более одним человеком - можно как угодно писать, но вот ты действительно стал разработчиком, попал в реальный проект, скажем на моменте когда в нем уже есть 500к строк, вот как думаешь, тебе бы было проще рабобраться с отдельным модулем, или лазить по свичам, ифам и прочему? Все эти паттерны придумали как раз для того чтобы ты не тратил потом месяц разбираясь что тут и для чего.
@alexanderalexander1637
@alexanderalexander1637 2 жыл бұрын
при беглом чтении иф читается как фи
@impnumb5713
@impnumb5713 6 жыл бұрын
Кода стало ещё больше :/
@rsakutin
@rsakutin 6 жыл бұрын
3 причины почему это плохо
@shadow_collider
@shadow_collider 4 жыл бұрын
@@rsakutin 3 причины, почему это хорошо? Чем больше кода -> больше байта на обработку, в любом случае весь программный код перекомпилируется на стандартные условия, тот же if (блоки условий), создать массив можно гораздо проще, включая методы доступа...
@АлексейВениченко-ш2в
@АлексейВениченко-ш2в 4 жыл бұрын
@@rsakutin А так же ухудшилась читаемость кода. И скорость работы программы.
@Ams-sv5bf
@Ams-sv5bf 4 жыл бұрын
я пока не посмотрел видео, но как я понял там все условия заменяют на тернарные операторы
@mimineko3100
@mimineko3100 6 жыл бұрын
Лучшее - враг хорошего. На 3 минуте, мой мозг больше не выдержал увиденного... ЗАЧЕМ нужно намеренно усложнять то, что проще простого?! В простоте совершенство! И ещё, играм нужен НЕ красивый, а ЛУЧШИЙ код! - Лучший для игры, а не для кого-то, кто вздумает его читать. (впрочем, читающему вот такой код, где даже условные операторы заменены классами, я уж точно не позавидую...) А для игры лучше тот код, который оптимальней, меньше засоряет память, кучу, меньше нагружает процессор. Но как правило, чем код "правильней" и "красивее", - тем он наоборот, ХУЖЕ для самой игры! Так например, многие стремятся избавлятся от связанности, переносить всё на события и делегаты... - а на деле потом получают в игре, торможения и глюки! А простой связанный код, работает и летает. Да и примеры не корректны. Ну кто так будет делать программу? ну разве что, новички. Обычно, любая однотипная обработка, и так, сразу оформляется как процедура или функция. А ты вот возьми те же IF или Switch, и в каждую секцию, помести абсолютно разные, уникальные обработки и действия. - ну и как ты это без IF сделаешь? Нет ну есть конечно варианты, через лямбда-выражения выёживать (на хабре было описано), но гемора, и опять же, ударит по производительности.
@rsakutin
@rsakutin 6 жыл бұрын
Через полиморфизм сделаю, для этого он и нужен. В конце я эту ситуацию описал.
@ssemyon9421
@ssemyon9421 4 жыл бұрын
@@rsakutin Я с человеком согласен - ужас. Это видео - троллинг?
@denisdubovik228
@denisdubovik228 2 жыл бұрын
Ты сейчас так это говоришь как яндере дев
@Dragon46938519
@Dragon46938519 3 жыл бұрын
не разжевал, слишком быстро
@vosureLife
@vosureLife 4 жыл бұрын
дэмЭджейбл
@Lesh50
@Lesh50 4 жыл бұрын
Это и так было известно
@КонстантинФедуров
@КонстантинФедуров 3 жыл бұрын
А чем паттерн "Состояние" отличается от паттерна "Шаблонный метод "
@apex_grove
@apex_grove 4 жыл бұрын
Очень полезная инфа, но визуальная подача не очень. Слишком быстро пишешь код и так же быстро скроллишь, дергаешся между сотроками, не давая времени на осознание написанного кода.
@ІгорПапроцький-я4д
@ІгорПапроцький-я4д 4 жыл бұрын
Для осознания кода существует пауза на видео. Имхо неудобства при просмотре не ощутил
@apex_grove
@apex_grove 4 жыл бұрын
@@ІгорПапроцький-я4д если сравнивать с видео гайдами, например от unity, то само качество подачи и отображения кода там на порядок выше
@ІгорПапроцький-я4д
@ІгорПапроцький-я4д 4 жыл бұрын
@@apex_grove на вкус и цвет... Например многим лучше когда автор пишет код быстро и не тратит их время на выписывание каждого куска кода очень медленно
@СергейФёдоров-щ8ш
@СергейФёдоров-щ8ш 4 жыл бұрын
Профан. Не смотрите, чушь несет. Методы правильные, но не понимает зачем это делает. Аргументирует красивым кодом )... Корону побольше нарисуй, а то не поверят. Излишнее ветвление сбивает конвеер проца, при неправильном предсказании ветвления онным. На что может потребоватся до ххх тактов. Избавление ветвления делается именно для этого.
@ЛёхаБодунов-б7ж
@ЛёхаБодунов-б7ж 4 жыл бұрын
То есть по-твоему читаемость, расширяемость и изменяемость кода не имеет значения? Для огромного числа приложений удобство поддерживания и стоимость разработки в приоритете над скоростью работы.
@СергейФёдоров-щ8ш
@СергейФёдоров-щ8ш 4 жыл бұрын
@@ЛёхаБодунов-б7ж Ну не знаю, какая тут читаемость улучшилась. Автор сам это говорит, после оптимизаций... Кода стало больше, и явно он сложнее для понимания чем простой case. Единственное что улучшилось, это возможность добавления новых условий в массив, возможно даже динамически, но ты, опять же, об этом не сказал. Ну и грамотный программист, опять же, конечно скажет про конвеер и т.д. и разжует, а тут все очень поверхностно. Дилетанты...
@Midavok
@Midavok 4 жыл бұрын
Обожаю оптимизаторов. Из маленького говно кода, который хорошо читался, сделал большой, но менее читабельный. И главное - на это было убито время, которое можно было потратить на написание нового кода.
@stanislavsh6582
@stanislavsh6582 4 жыл бұрын
Это не оптимизация, а рефакторинг. Это раз. Два, потратив время на написание этого кода ты сокращаешь объем работ в будущем. Конечно, если программа которую ты пишешь это калькулятор на обратной польской записи, то ничего такого действительно не нужно, но представь что у тебя сложная система управления комплексом устройств, а к этому еще и api прекручено чтобы можно было свой UI запилить, плюс клиенты хотят с разными базами данных работать из-за того что ну купили они прокачаную версию и их MySql не устраивает теперь(ну или как в рф - меньше вопросов к твоему софту если берешь отечественную разработку). Вот как думаешь, сколько ты потратишь времени чтобы добавить поддержку пары новых устройств, переписать все запросы что ты написал для MySql на какой-нибудь Postgre так чтобы остальную логику нигде менять не нужно было, ну или найти баг, когда у тебя там свичи в 100к строк в куче мест?
@Midavok
@Midavok 4 жыл бұрын
@@stanislavsh6582 что такое оптимизация и рефакторинг ты знаешь, а вот что такое сарказм - похоже нет. Это первое. Второе. В погоне за красивым кодом можно дойти до абсурда, слепо следуя одним принципам и полностью забивая на другие, например на KISS. И да! Если у тебя в коде 100 к строк свичей, то твой код говно, а ты говнокодер. Прими это.
@stanislavsh6582
@stanislavsh6582 4 жыл бұрын
​@@Midavok Как раз руководствуясь KISS и приходишь к тому что у тебя switch с миллионом case'ов или куча if'ов в коде, а методы раздуваются, няша. Посмотри на пример кода YandereDev'а, он-то как раз не гнался за красивым кодом, и что имеем в конечном итоге? Маленькое нововведение в игру занимают по полгода. Да блин, попробуй начать писать хотя бы платформер, добавляя постепенно новые фитчи, инвентарь игрока, систему покупок бафов, разные типы врагов и их взаимодействие друг с другом(например если моб ударит другого то они начинают друг с другом драться), ты поймешь что KISS это конечно весело, когда ты пишешь хелловорлды и калькуляторы, но когда нужно делать даже средний проект, скажем на 100к строк, то как-то уж лучше заложить в самом начале возможность для роста и развития, чем потом плеваться и переписывать все это, либо плакать, но есть катус.
@Midavok
@Midavok 4 жыл бұрын
@@stanislavsh6582 про 100к свичей могу заметить только, что не надо путать "делай проще" с "делай тупо". Ты либо не читал " Совершенный код", либо нихрена не понял. Печально
@stanislavsh6582
@stanislavsh6582 4 жыл бұрын
​@@Midavok Да Господи. Так пишешь, будто никогда не имел дело с легаси, а только по книжкам с реальной ситуацией в программировании знаком. Людям ставили изначально простую маленькую задачу и они пилили побыстрее, а потом продукт оказывался успешным, в него пихали новые фитчи, и оказывается, что уже фиг что впихнешь, так чтобы все не сломалось к чертовой бабушке, потому что все же такие прошаренные, у них KISS всюду, потому давайте нафигачим глобальных переменных, удобно же из любого места можно получить доступ, давайте нафигачим синглтонов где не надо, давайте у нас вообще половина программы на статике будет, ну а фига ли, а потом у них все разваливается, они быстренько уходят в другую контору и пусть новые программисты занимаются поддержкой и развитием этого. Ну да, удобно. Зато делали как проще. Только кому и что? Проще писать такой код - безусловно, проще ли потом нормально поддерживать и развивать - да хрен там. Зато анекдоты в комментариях пишут, ишь какие молодцы.
@АндрейПагосов
@АндрейПагосов 4 жыл бұрын
Visual Studio на русском - жесть, исправь плиз на English
Chain Game Strong ⛓️
00:21
Anwar Jibawi
Рет қаралды 41 МЛН
3D Графика в консоли на C# / 3D Graphics Console C#
10:32
КОД КАК У СЕНЬОРА. РЕФАКТОРИНГ
22:59
ITentika Online
Рет қаралды 70 М.
THE MOST FREQUENT MISCONCEPTIONS ABOUT OOP
19:37
ExtremeCode
Рет қаралды 561 М.