Сразу скажу - каких-то откровений не ждите. Так - по верхам. Именно что слегка вспомнить (ну разве что ранее совсем не сталкивались с async/await в .Net - тогда даже что-то полезное найдете)
@johnnya512827 күн бұрын
Класс. Продолжайте в том же духе.
@nouchanceАй бұрын
Спасибо Михаил👍👏
@waldemarperegud4885Ай бұрын
Большое спасибо!
@kiryas_Ай бұрын
Михаил, Спасибо Вам за эти отличные, информативные лекции. Пожалуйста, продолжайте!
@nouchanceАй бұрын
Спасибо!
@reindeermosseaterАй бұрын
ORM нужен для того, чтобы для менеджмента разраб обходился в два раза дешевле. Разрабу ОРМ не нужен.
@mihail_romanovАй бұрын
Это уж пусть каждый решает для себя сам - нужен ему в работе ОРМ или нет, а если нужен, то какой. Я вот встречал коллег, которые вполне обходились в работе и без отладчиков и без IDE - и вполне чувствовали себя уверенно. А я вот так не умею и привыкать к такому не хочу.
@reindeermosseaterАй бұрын
@@mihail_romanov отладчики то здесь причем. я тоже встречал убежденных орм-щиков, которые насочиняли систему, которая у них прекрасно работала (гомеопатические объемы), пока ее не поставили заказчику (объемы данных детские, но уже не гомеопатические). после чего мне пришлось все переделывать. И суть не в том, что ОРМ не умеет в оптимальные вопросы, а беда в том, что она заставляет разраба мыслить объектами, в то время как в базе ДАННЫХ лежат данные. И все методы заточены на экземпляры сущностей. А если там еще трехзвенка, то вызова удаленного метода сначала сериализуй, потом там десериализуй, и затем с ответом все тоже самое. Хотя да, расписание уроков пятого бэ для младшей сестры написать можно. будет замечательно работать.
@mihail_romanovАй бұрын
> а беда в том, что она заставляет разраба мыслить объектами, в то время как в базе ДАННЫХ лежат данные. Пока не вижу проблемы. > И все методы заточены на экземпляры сущностей. А если там еще трехзвенка, то вызова удаленного метода сначала сериализуй, потом там десериализуй, и затем с ответом все тоже самое. Я правильно понимаю, что главное зло ORM вы видите в материализации (переводе результатов запросов в объекты)?
@reindeermosseaterАй бұрын
@@mihail_romanov не совсем. sql девелопер мыслит данными, и пишет запросы, возвращающие ему только нужные данные. А ОРМщик мыслит своими классами-сущностями. Вот простой пример. Допустим у нас в предметке есть вложенные сущности: маленькая упаковка, большая коробка для упаковок и поддон (палетта) на которой лежат много больших коробок. В итоге на одной палетте может лежать 50К первичных (маленьких) упаковок. Теперь нам надо отгрузить пару палетт контрагенту. У ОРМщика будет IPallet у которой свойство - коллекция "большие коробки" ICrate, а у каждой большой коробки будет коллекция упаковок IBox. Кладовщик сканирует штрих код палетты и ОРМщик идет доставать всю эту палетту со всеми 50К чайлдами. Затем по итогу один единственный long (ID палетты) инсертится в таблицу отгрузки контрагента. А надо было всего-то найти один лонг по штрихкоду палетты. Но это если двузвенка! А там мульттаер через rabbitMq. А так как на сервере приложений метод отгрузки хочет IPallet, то ормщик сериализует это в многомегабайтный блоб и отправляет на кролика. Затем получает оттуда такой же многомегабайтный ответ. А когда ему говоришь, что по крайней мере серверный метод можно сделать не на IPallet, а на long то в ответ слышно следующее: "НО ТЕПЕРЬ ЖЕ В МЕТОД МОЖНО ПЕРЕДАТЬ ВООБЩЕ ЛЮБОЙ ЛОНГ, и о боже! КОМПИЛЯТОР МНЕ НИЧЕГО НА ЭТО НЕ СКАЖЕТ!!!!!" Короче говоря, ормщик очень много думает о том, чтобы удобно было ему, и абсолютно не думает о том, как это будет работать у заказчика.
@nouchanceАй бұрын
Spasibo
@unicoxr5tj417Ай бұрын
поддержка лайком. Автор, добавь стек C#, например, или еще что, или допиши заголовок, если это универсальное решение
@mihail_romanovАй бұрын
Можно чуть подробнее: что именно и куда нужно добавить или поменять и для чего?
@mihail_romanovАй бұрын
А... Кажется понял - из названия не ясно, что это .Net. Я просто начал выкладывать эти лекции в рамках курса .Net Core и как-то не задумывался, что кто-то будет приходить со стороны. Поэтому нигде не обозначено, что за стек. Понял, спасибо за полезную мысль - чуть разгребусь и пробегусь по всем лекциям, добавлю пометку.
@unicoxr5tj417Ай бұрын
@@mihail_romanov да я про это, C# или .NET добавит релевантных просмотров
@waldemarperegud4885Ай бұрын
Большое спасибо!
@waldemarperegud4885Ай бұрын
Большое спасибо!
@waldemarperegud48852 ай бұрын
Большое спасибо!
@ГлебЛитвинов-ф4ш2 ай бұрын
Блин чувак, контент в кайф, так держать, давай давай давай вперед. Держу за тебя кулачки ✊✊✊
@Георгий-ь6с2 ай бұрын
Спасибо, очень полезно и все понятно!
@waldemarperegud48852 ай бұрын
Большое спасибо!
@waldemarperegud48852 ай бұрын
Большое спасибо!
@Mark-pm5gh2 ай бұрын
Отличный материал 👍
@iiiiiuuiuiui43032 ай бұрын
Большое спасибо
@rutorikouman93863 ай бұрын
Спасибо за видео)
@nouchance3 ай бұрын
Спасибо!
@UserMan-e4j4 ай бұрын
Очень полезно! Можно слайды ?
@mihail_romanov4 ай бұрын
Конечно. Все материалы тут github.com/MihailRomanov/net_core_course
@KybaLioN664 ай бұрын
Спасибо за видео. Хочу прояснить один момент. В C++ есть встроенные типы (int, float, double и т. д.). Это всё так сказать честные типы, без каких либо обёрток. В Java тоже есть такие примитивные типы, но на них когда пытаёшься вызвать метод то компилятор содаёт reference wrapper. для примера для int будет создан эксземпляр класса Integer. Как я понимаю встроенные коллекции даже не могут хранить value types. В С# не много путаница. У нас все value types это струсктуры которые наследованы от структуры ValueType. Как я понимаю System.Int32 инкапсулирует примитивный тип int как в С++. Но в этом классе есть m_value который тоже экземпляр класса System.Int32. Вопрос как runtime создает примитивный тип в нутри себя ? Вопрос может быть не точен. просото для меня runtime это программа написанное на С++, который выполняет IL код. И если где то определено value type, для него он должен создать примитивный тип.
@mihail_romanov4 ай бұрын
Вопрос хороший прямо досконально не расскажу - я и не на столько глубоко погружен в платформу и компилятор, и в комментарии это сделать сложно... Но если в 2-х словах, то: 1. На уровне runtime (IL) есть поддержка примитивных типов данных (int32, int64, ...). Она включает в себя: операции с разными типами (загрузка в стек, выгрузка, арифметические операции, ...), объявление локальных переменных в процедурах (потом можно к ним обращаться в командах), использование примитивных типов в качестве полей в объектах и структурах (там тоже специальные команды типа "загрузи поле XXX объявленное в типе YYY, из объекта ZZZ"), при передаче параметров в методы, и возврате результатов Т.е. на уровне IL int32 это именно простейший тип, не структура и не класс. 2. В BCL такие типы объявлены как структуры с одним единственным полем m_value с тем же типом, как и сама структура. Т.е., с точки зрения C# (да и вообще .Net) - недопустимая вещь! Поэтому структура System.Int32 (как и остальные примитивные типы) при компиляции обрабатывается специальным образом: - игнорируется, то структура используется внутри себя (я про поле m_value) - т.к. у структуры, в отличие от объекта, нет всяких скрытых дополнительных полей (ссылки на метаданные, поля sync, ...) то System.Int32 в памяти хранится как просто число. Поэтому ссылаемся мы на , или на , или на поле в - генерируется один и тот же код - который работает с IL-типом Иными словами, если бы это была бы обычная структура, то при компиляции внутренних методов, которые обращаются к полю использовались бы конструкции типа или а вот тут ничего похожего не будет. Ну и в обычном коде, везде, где идет работа с System.Int32 при генерации IL просто происходит замена на int32. Кстати, у описания типа (класса Type) есть поле , которое и позволяет узнать - является ли тип примитивным или это обычная структура 3. Из того, что осталось - это вызов методов. Здесь примитивные типы ничем не отличаются от обычных valuetype: - когда вызывается статический метод, то у него нет никаких неявных параметров, мы обязаны аргументы объявить явно. Ну и структура по умолчанию передается по значению (копированием). - если вызывается обычный (не виртуальный) экземплярный метод, то у него есть один неявный параметр - ссылка на экземпляр структуры, для которой он вызывается. Здесь всё как и у объектов - загружается адрес. Например Int32 a = 5; var t= a.CompareTo(44); Перед вызовом CompareTo, в стек будет загружен адрес локальной переменной и константа 44. - вызов перегруженных виртуальных методов (т.к. valuetype друг от друга наследовать нельзя, то виртуальные методы - только от Object: GetType(), Equal(), ToString()), вот для них прежде чем вызывать виртуальный метод, делается операция boxing - она создает в куче объект (со всеми доп. полями - той же ссылкой на метаданные!) и копирует в него содержимое структуры, а уже потом делает (и этим boxing опасен - создается копия, а не ссылка!) Но у valuetype есть определенная оптимизация. Для них вместо прямого box вызывается инструкция , которая сначала проверяет - реально ли нужен boxing (если вызывается перегруженный метод - тот же ToString(), то нет) и только если он необходим, она делает . P.S. Прошу прощения - получилось немного сумбурно. Я, к сожалению, не нашел нигде нормальной статьи, где бы это было описано, поэтому даже ссылку не могу дать, где бы почитать подробнее. Многие ссылаются вот на эту статью web.archive.org/web/20141124091806/weblogs.asp.net/dixin/understanding-net-primitive-types, но там тоже не всё и без особых подробностей.
@KybaLioN664 ай бұрын
@@mihail_romanov Спасибо вам огромное. За ваш большой труд. Собрать всю эту информацию во едино не простая задача. Да, тема доволна сложная, есть слой так сказать магии которая не понятна. Так как сейчас только начинаю изучение, то можно и опустить такие моменты для начало. Но по этой теме может помочь давольна популярная книга CLR via С# by Jeffrey Richter.
@mihail_romanov4 ай бұрын
CLR via С# действительно очень неплохая книга (я вообще могу сказать, что все книги, что мне попадались у Рихтера, были феноменальными по охвату и глубине), но: - книга довольно сложная и новичка может даже запутать. Т.е. я бы её не стал читать как первую книгу по .Net/C# (да и язык там практически не упоминается) - книга старая. Если не ошибаюсь, последнее издание было для .Net Framework 4.5. С выходом Core и более поздних версий .Net что-то поменялось, что-то стало неактуальным и нерекомендуемым к использованию, для чего-то появились другие механизмы, ... К сожалению, Джеффри больше не пишет книг, а других авторов такого уровня я просто не знаю.
@rutorikouman93864 ай бұрын
Доходчиво и информативно, спасибо
@KybaLioN664 ай бұрын
Спасибо за видео. Как я понял былди которые демонстрированы в видео, при исполнении требует уже установленный заранее виртуальной машины .NET (CLR). Но я знаю что возможно собрать так сказать в standlone project. Где в exe файле будет зашито виртуальная машина. и этот билд можно запускать в любой среде без каких либо зависимостей. Можете сказать плюсы и минусы этих подходов ?
@mihail_romanov4 ай бұрын
Ну я бы тут говорил о 2-х подходах: - self-contained сборка (и публикация) проекта. Здесь всё те же IL библиотеки, но (!) в процессе сборки всё, что нужно для запуска приложения: исполнимый файл, runtime и библиотеки .Net, сторонние зависимости, ... - будет собрано в одну папку. И этого будет достаточно для запуска, никаких требований к окружению (ну кроме поддерживаемой версии ОС) не будет. Подробнее тут learn.microsoft.com/en-us/dotnet/core/deploying/#publish-self-contained - там же указаны плюсы и минусы подхода. Самое главное из плюсов - доступны любые библиотеки и возможности .Net - Native AOT (ahead-of-time). А вот тут происходит компиляция сразу в исполнимый код, и да, собирается всё в общий исполнимый файл. Опять же подробнее можно почитать тут learn.microsoft.com/en-us/dotnet/core/deploying/native-aot Основные сложности, как по мне, это некоторый функционал (например, часть Reflection) не доступен, а значит и те библиотеки, что от него зависят - не доступны тоже. Например тут learn.microsoft.com/en-us/aspnet/core/fundamentals/native-aot?view=aspnetcore-8.0#aspnet-core-and-native-aot-compatibility указан функционал ASP.Net Core, совместимый и несовместимый с AOT. К сожалению, у меня пока не было поводу поработать с AOT, поэтому какого-то своего мнения у меня пока тоже нет. Как по мне, для классических серверных приложений это не особо актуально (разве что для быстрого запуска serverless функций - но в моей текущей практике этого не требуется), а вот ограничения по функционалу - очень существенны.
@KybaLioN664 ай бұрын
здравствуйте, спасибо за лекцию. Только начал изучение этой платформы. До этого занимался только С++. хочу спросить, эти видео для ютуба, или для аудитории какой нибудь школы ? и ещё одно маленькое замечание по поводу звука, звук очень тихий.
@mihail_romanov4 ай бұрын
Не очень понял про аудиторию ("видео для youtube" - не совсем понятно, чем это видео должно отличаться от какого-то другого). Это видео к учебному курсу github.com/MihailRomanov/net_core_course Он для команды с определенным опытом разработки, но которая ранее никогда с .Net не работала. Или вы про то, какие права/ограничения? Тут никаких - пользуйтесь любыми материалами без проблем. Про звук - буду иметь в виду. Это конкретно с текущем видео проблемы или со всеми из этого плейлиста?
@KybaLioN664 ай бұрын
@@mihail_romanov иногда авторы выкладывают видео с оффлайн курсов, но не все, вот и спросил чтобы узнать будет ли полноценный курс, или вы будете выкладывать всё что есть. Просто поражаюсь вашим подходом и професионализмом. Все очень четко и по порядку. Хотелось начать и закончить курс по .NET именно с вашим курсом. Про звук, это не критично, мне как и многим другим специалистам важно качество материала а не монтаж звук и анимации. Спасибо за ваш труд. Хотел ещё спросить про книги. Так как я знаю С++, мне не нужно книги для начинающих. Нашёл для себя вот эту книгу Professional C# and .NET 2021st Edition by Christian Nagel (Author). Знакомы ли вы с этой книгой ? если да то как оно вам ?
@mihail_romanov4 ай бұрын
Я этот курс веду удаленно и выкладываю все лекции и все материалы. Основная площадка здесь, но из-за возникающих периодически проблем, пришлось сделать копии на других. Так что тут будут выложены все запланированные лекции. Другой момент, достаточно ли вам будет того, что включено в курс. Могу точно сказать, что не будет ничего по Desktop UI. По основам ASP.Net Core планируется отдельный курс, который начнется сразу вслед за текущим и материалы по нему, я также планирую разместить на этом канале. Что касается книг, то тут, увы, по состоянию на сегодня я вряд ли смогу сориентировать. Ранее, мне очень понравилась Joseph Albahari and Ben Albahari C# 7.0 IN A NUTSHELL - она точно переиздавалась для более поздних версий языка. Она мне показалось лаконичной, но достаточно полной для хорошей основы Еще могу порекомендовать взглянуть на metanit.com/sharp/tutorial/ - может не супер глубоко, но достаточно неплохо изложено.
@KybaLioN664 ай бұрын
@@mihail_romanov большое спасибо .
@KybaLioN664 ай бұрын
thank you very much
@nouchance4 ай бұрын
спасибо!
@do86034 ай бұрын
Смотрел и думал что наткнулся на древнее видео. Потом взглянул на дату и нереально удивился. Парень, проснись, ты десятилетие проспал
@mihail_romanov4 ай бұрын
К сожалению я не очень понял смысл вашего комментария. Что именно вы хотели донести мыслью про мой десятилетний сон? - Что-то из рассказанного в видео не может применяться в настоящее время? Было бы полезно узнать что именно и почему. - Или вы ожидали увидеть некую информацию, которую ныне следует отнести к категории "обязательно"? Аналогичный вопрос - о чем именно речь. Буду очень признателен за развернутый конструктивный комментарий.
@nouchance4 ай бұрын
спасибо!
@Mark-pm5gh5 ай бұрын
Великолепный материал.
@mihail_romanov5 ай бұрын
Благодарю!
@PhilKleymenov5 ай бұрын
Спасибо Михаил, я снова как будто в 2008 оказался
@mihail_romanov5 ай бұрын
Увы, из вашего комментария я не смог понять: рады вы этому обстоятельству или наоборот... Но для себя решил считать, что вам понравилось, а значит уже не плохо.
@PhilKleymenov5 ай бұрын
@@mihail_romanov вы большой молодец, спасибо вам!
@Serj-eu3zp5 ай бұрын
И в этом, и в предыдущем видео (другие не запускал) как-то очень странно местами подлагивает звук. На других каналах всё ок, возможно у Вас что-то не так при записи
@mihail_romanov5 ай бұрын
Да, правда, есть такое. Спасибо! Подумаю ,что с этим можно сделать, пока с ходу не разобрался, что не так, но есть подозрение.
@mihail_romanov5 ай бұрын
Еще раз спасибо за наводку. Да, проблема (пусть и не так заметно) есть и в остальных видео. В общем, что удалось понять: - в исходных файлах в этих местах есть какие-то небольшие шумы, но они не очень заметны (открываю локальным проигрывателем) - при загрузке на KZbin и VK Video проблемы становятся очень заметными, вместо неясных шумов появляются четкие щелчки. Я было подумал, что проблема в браузерах, но: во всех браузерах одинаковые проблемы, зато при открытии локального файла (в тех браузерах, где разобрался как) - проблемы нет. - более того, при загрузке на Rutube проблема тоже не проявляется (по крайней мере я не слышу). - поиск в интернете показывает, что проблема "после загрузки на KZbin появляются щелчки в звуке" не так и редка, а вот решений я с ходу не нашел. Так что мое предположение: - на YT и VK при перекодировании видео используется какой-то фильтр (какой именно предполагать не берусь - не специалист), который на определенных файлах дает неожиданный эффект Приложу ссылку на плейлист с Rutube rutube.ru/plst/488407 и на такое же видео rutube.ru/video/7555d579673c3c035172a2a4f4ce1592/ если будет возможность сравнить, буду признателен
@ВладВлад-у6ш5 ай бұрын
Часто применяете синглтон с двойным локом ?
@mihail_romanov5 ай бұрын
Откровенно говоря, я вообще последнее время синглтон руками не реализую: - если пишется простая утилита, то контролировать время жизни и количество экземпляров просто и без дополнительных ухищрений - а если речь идет о крупных приложениях, то всё бремя управления ЖЦ объектов передается на класс хоста, который также предоставляет IoC-контейнер. Т.е. мы просто регистрируем класс (или сразу экземпляр) как синглтон, а потом создаем его исключительно средствами хоста/контейнера. Здесь же я взял для примера именно синглтон потому что: - он концептуально прост и понятен (т.е. не нужно долго и сложно объяснять, какую задачу мы решаем) - но при этом есть много вариантов реализации, как более-менее универсальных, так и опирающихся на особенности языка/среды. Т.е., как по мне, ну очень хороший пример для того, чтобы проникнутся идеей "для чего стоит почитать о паттернах проектирования". Если я кого-то заинтересовал - значит цель достигнута.
@iiiiiuuiuiui43035 ай бұрын
спасибо за подробный урок
@mihail_romanov5 ай бұрын
Рад что вам понравилось. Заходите ещё - может быть найдется что-то полезное помимо этой лекции. Курс не закончен, видео будут ещё выходить.
@0x10FFEF5 ай бұрын
старинное объяснение которое уже не используется
@mihail_romanov5 ай бұрын
А можно чуть подробнее? О каком объяснении речь, почему не используется и что используется ныне?
@Tunec_s_hlebom5 ай бұрын
@@mihail_romanov нужно короткое видео с поверхностным объяснением темы, но с крутой музыкой, монтажом, кучей крутых айтишных слов и кривляниями чтобы молодежь захотела смотреть😅. И в конце обязательно надо сказать что этих знаний хватит чтобы устроиться на 300К в наносекунду
@mihail_romanov5 ай бұрын
Увы, в таком формате у меня шансов 0. Из всего перечня я вытяну разве что "кучу IT-шного сленга", да и то, как мне верно указали в комментариях под соседним роликом, могут быть проблемы с произношением.
@ill43745 ай бұрын
@@Tunec_s_hlebom хауди хо, Друзья!
@АстрамарийЦелеборКраш4 ай бұрын
Михаил! Я только начинающий итишник и до этих тем пока не добрался, НО! я тут почитал мнения, ну, наверное экспертов, объективно мне судить ещё рано,и могу с уверенностью сказать что вы делаете однозначно полезное дело, объясняя структурировано и систематезировано основы. Ибо это база. Это делает специалиста специалистом. Так что, спасибо вам большое.
@bulsond5 ай бұрын
Спасибо, за хороший урок. Одно замечание: буферА у телёчек, а бУферы у потоков.
@mihail_romanov5 ай бұрын
Предлагаю сойтись на варианте "это особенности предуральского выговора" :) Но за замечание спасибо - учту (по крайней мер постараюсь)
@Дмитрийсекрет-н7о6 ай бұрын
Однако сложно. Но интересно. Спасибо за погружение в тему.
@mihail_romanov6 ай бұрын
Я старался как мог структурировать - чтобы легче воспринималось. Но тема с непривычки всё равно, наверное, воспринимается тяжело. Думаю, тут как и везде - начнешь применять на практике -> потихоньку придет понимание -> а дальше уже будет почти интуитивно получаться.
@Дмитрийсекрет-н7о6 ай бұрын
@@mihail_romanov Так точно. Главное практика.
@Aleksey-s5h6 ай бұрын
А ведь интересно рассказываеш. Спасибо за видео. С удовольствием посмотрел.
@mihail_romanov6 ай бұрын
Спасибо. Буду стараться и дальше.
@katyama87 ай бұрын
spasibo!!!!!!
@mihail_romanov6 ай бұрын
Рад что вам понравилось, и, надеюсь, было полезно.
@evgenysmirnov47627 ай бұрын
Fluent синтаксис прям как в Rails...
@mihail_romanov6 ай бұрын
А идея общая, так что логично. Я вообще впервые о Fluent прочитал, если не путаю у Фаулера martinfowler.com/bliki/FluentInterface.html