You prolly dont give a shit but if you are stoned like me during the covid times then you can stream pretty much all the latest series on InstaFlixxer. Have been watching with my brother for the last couple of months =)
Еще один из наглядных примеров использования модификатора static в классе, это подсчет количества созданных объектов класса (объявляем целочисленное поле в классе с модификатором static, и в конструкторе(ах) увеличиваем его на единицу, в итоге в этой статической переменной будет число созданных экземпляров класса (объектов)). Спасибо за очередной урок!
Наверное один из тех каналов по программированию, где реально хорошее, разжеванное объяснение и качественная подача материала, что даже обычному человеку понятно
Капец, Степан, объяснение - выше всяких похвал. На разных курсах, в документации - все далеко не так понятно, у Вас определенно талант преподавать! Спасибо большое.
неудобство static получается в том, что однажды его прописав и создав массу обращений к нему, убрать static (если вдруг понадобится) превратиться в рутину , чтобы изменить код
Если создать 1000 потоков которые позовут calc.Add с рандомными числами в одну секунду, этот статический метод инстанцинируется для каждого потока чтобы посчитать корректные суммы? Как реализован thread safe для static?
Спасибо за видео. Можете рассказать, почему кто-то рекомендует писать код программы без static? Т.к. static помогает дешифровать и узнать код программы. То есть это мешает безопасности кода
Спасибо за видео. Подскажите пожалуйста, если мое приложение работает с базой данных, например интернет-магазин. Единовременных пользователей ожидается немного, и каталог товаров тоже очень маленький. Позиций 100-200. У каждого товара полей тоже мало. Id, название, категория, цена. Я создал класс DataAcessLayer, он динамичный. Создаю экземпляр класса каждый раз, как обращаюсь к БД. Для поиска товаров, просмотра категорий товаров, сортировки по ценам и т.д. Сейчас я делаю это логикой sql запросов (вернуть только категорий, вернуть товар по id, вернуть товары дешевле 100 рублей и т.д.) Всё работает, но каждое простейшее действие пользователя по отображению товаров или их сортировки создает экземпляр класса dal и обращение к БД. Я подумал взять и выгрузить в ОЗУ весь лист обьектов из таблицы товаров в БД, чтобы к ней не лезть каждый раз. И делаю промежуточный класс между DAL и логикой. В этом промежуточном классе я просто один раз в пять минут загружаю таблицу товаров из БД (сама таблица в БД меняется раз в месяц, так что пять минут-норм). Храню в этом промежуточном классе приватную переменную - лист объектов (товаров). И сам в этом классе пишу публичные методы, возвращающие категории товаров, цены, список товаров и т.д. Чтобы на каждый чих пользователя не лезть в БД. Отклик от БД все равно 100-200мс, а так должно быть быстрее. Нормально ли, что я сделал этот промежуточный класс статическим? Т.е. создается один экземпляр на все время работы программы. К БД больше лезть не нужно постоянно, и возврат ограниченного списка товаров, сортировку и т.д. я теперь реализую в этом классе, а не специфичными sql запросами к БД. Или это экономия на спичках и дурной тон? Или если сделать сам класс DAL статическим, это дурной тон, или наоборот хорошая практика? Я понимаю, что всё завсисит от архитектуры конкретного приложения, но может быть есть общий ответ типа "так делать нельзя" или "да, так лучше". Спасибо. P.S. с другой стороны, таким образом я отказываюсь от асинхронности и мои async-await будут упираться в мои статичные методы единственного экземпляра статичного класса. Наверное, в продакшене такое решение как у меня не встречается, и принято обращаться кучу раз к БД? Мол, её не дураки писали, и там всё быстро работает?
Спасибо вам большое за курс уроков c# c нуля, хотелось бы у вас узнать сколько вы еще планируете выпусть роликов в этом цикле? Спасибо заранее за ответ!
Все проще. Есть методы экземпляра, есть методы типа. Вся их разница обусловлена именно этим различием. Как только становится доступен тип, доступны и его члены. Вот и все.
Вы описываете известные факты, но не отвечаете на вопрос почему так сделано. То, что есть static у методов и классов новички замечают почти сразу как только начинают программирование. Только вот почему так сделано им не понятно.
@@SBeregovoyRU Я в целом не против упрощенной подачи, но для меня было намного проще освоить материал о чем-то базовом и важном, а потом оттолкнуться от этого в чем-то более сложном. Давно известный факт, что структурированная подача/прием материала улучшает качество процесса. И поэтому, для меня, странно рассуждать о статике не имея представления о типах. А имея понимание о сути вопроса, факт2 объясняется сам собой, а то непонятно как язык может защищать от ошибок, особенно когда в студии этим занимается синтаксический анализатор кода)). Такто, в сишарпе есть много вариантов выстрелить себе в ногу, и все они достаточно высокоуровневые.. Ну и таа далее
Отлично объяснил, Степан! Новичкам зайдет и будет полезно 👍 И всё же что выбрать для helper'а - static или выделить память? Класс helper с методами, которые что-то подсчитывают, сравнивают и т.п. В плане оптимизации памяти стоит ли этот класс вешать как static, если обращаюсь к этим методам только один раз?
Здравствуйте Степан, хочу спросить если планируете в будущем снимать уроки по WPF и комбинировать с тем что научились в этих видео ? Спасибо из Чехии ;)
@@SBeregovoyRU спасибо за ответ а будет продолжение допустим в комбинации с вебом. Просто хотелось бы с консольного программирования перейти на более модерный способ применения С#.
Господи! Эта рубрика ещё жива.. Спасибо большое тебе за этот нелёгкий труд.
You prolly dont give a shit but if you are stoned like me during the covid times then you can stream pretty much all the latest series on InstaFlixxer. Have been watching with my brother for the last couple of months =)
@Ira Hamza yea, been using InstaFlixxer for since december myself :D
Еще один из наглядных примеров использования модификатора static в классе, это подсчет количества созданных объектов класса (объявляем целочисленное поле в классе с модификатором static, и в конструкторе(ах) увеличиваем его на единицу, в итоге в этой статической переменной будет число созданных экземпляров класса (объектов)). Спасибо за очередной урок!
хорошее дополнение!
Видео супер - никакой воды. Раскрывается "суть" очередной темы. Автору большое спасибо
а ты доску видишь на старте?
Наверное один из тех каналов по программированию, где реально хорошее, разжеванное объяснение и качественная подача материала, что даже обычному человеку понятно
Спасибо ! Жду новых уроков !
Очень здорово, что начинаешь с проблематики (факты)
Капец, Степан, объяснение - выше всяких похвал. На разных курсах, в документации - все далеко не так понятно, у Вас определенно талант преподавать! Спасибо большое.
Благодарю друг за работу тебя, все понятно, подробно !!!!
Про public private protected internal много рассказывают, а вот про static ни разу не слышал объяснений.
Спасибо огромное!!!
и вам спасибо, что смотрите и оцениваете
Степан, продолжай пожалуйста) Очень полезную инфу даешь
Спасибо за то, что я уже знал.
Спасибо. Наконец-то понял что это такое.
Долгое время эти статики мне в кошмарах снились, когда натыкался на них на других каналах ютуба.
Спасибо за урок. Ждём следующих.
Огромное вам спасибо!
Спасибо, Степан! Отличный урок🙂
Очень доходчиво. Раньше в созданные функции пихал по наитию всё
Ура!!!Урааа!! Новое видео, спасибо Степан
отличное объяснение, очень жаль, что вы Степан ушли с ютуба
Отличное видео)
А будет видос про интерфейсы?
будет
Вся путаница ушла)
Спасибо!
неудобство static получается в том, что однажды его прописав и создав массу обращений к нему, убрать static (если вдруг понадобится) превратиться в рутину , чтобы изменить код
гуд зер гуд )
Жду видео обзор на новые фичи C# 9.0
Читайте Рихтера CLR. Там все есть
статик означает что теперь классу будет на постоянной основе выделена память или это произойдет только когда мы его позовем даже без new?
Уроков больше не будет ?
Вполне красивое объяснение
спасибооооо
Вот бы Степан подготовил урок по модификаторам доступа...
Если создать 1000 потоков которые позовут calc.Add с рандомными числами в одну секунду, этот статический метод инстанцинируется для каждого потока чтобы посчитать корректные суммы? Как реализован thread safe для static?
Спасибо за видео. Можете рассказать, почему кто-то рекомендует писать код программы без static? Т.к. static помогает дешифровать и узнать код программы. То есть это мешает безопасности кода
О нет, при чем тут дешифровка... к static то, что вы написали не имеет никакого отношения
@@SBeregovoyRU я не сам это придумал, а услышал от блогера "XpucT". Что он так борется со взломом своей программы, поэтому и спросил у тебя:)
Ждем Степан, ждем...
Есть ли в планах записывать платные видео по asp net core?
да, есть в планах такие видео
Степан делайте видео почаще))
Привет Степан. Уроки здесь уже месяц не выходят((( когда же появятся новые видео?? ждем , печаль(((
Привет! Последний видео урок был 15 ноября.
Спасибо за видео.
Подскажите пожалуйста, если мое приложение работает с базой данных, например интернет-магазин. Единовременных пользователей ожидается немного, и каталог товаров тоже очень маленький. Позиций 100-200. У каждого товара полей тоже мало. Id, название, категория, цена.
Я создал класс DataAcessLayer, он динамичный. Создаю экземпляр класса каждый раз, как обращаюсь к БД. Для поиска товаров, просмотра категорий товаров, сортировки по ценам и т.д. Сейчас я делаю это логикой sql запросов (вернуть только категорий, вернуть товар по id, вернуть товары дешевле 100 рублей и т.д.) Всё работает, но каждое простейшее действие пользователя по отображению товаров или их сортировки создает экземпляр класса dal и обращение к БД.
Я подумал взять и выгрузить в ОЗУ весь лист обьектов из таблицы товаров в БД, чтобы к ней не лезть каждый раз. И делаю промежуточный класс между DAL и логикой. В этом промежуточном классе я просто один раз в пять минут загружаю таблицу товаров из БД (сама таблица в БД меняется раз в месяц, так что пять минут-норм). Храню в этом промежуточном классе приватную переменную - лист объектов (товаров). И сам в этом классе пишу публичные методы, возвращающие категории товаров, цены, список товаров и т.д. Чтобы на каждый чих пользователя не лезть в БД. Отклик от БД все равно 100-200мс, а так должно быть быстрее.
Нормально ли, что я сделал этот промежуточный класс статическим? Т.е. создается один экземпляр на все время работы программы. К БД больше лезть не нужно постоянно, и возврат ограниченного списка товаров, сортировку и т.д. я теперь реализую в этом классе, а не специфичными sql запросами к БД. Или это экономия на спичках и дурной тон?
Или если сделать сам класс DAL статическим, это дурной тон, или наоборот хорошая практика?
Я понимаю, что всё завсисит от архитектуры конкретного приложения, но может быть есть общий ответ типа "так делать нельзя" или "да, так лучше".
Спасибо.
P.S. с другой стороны, таким образом я отказываюсь от асинхронности и мои async-await будут упираться в мои статичные методы единственного экземпляра статичного класса.
Наверное, в продакшене такое решение как у меня не встречается, и принято обращаться кучу раз к БД? Мол, её не дураки писали, и там всё быстро работает?
Отличные уроки, некоторые моменты достаточно глубоко расказываешь. Ты не собираешься разбирать книгу CLR via C#, хотя бы первую главу?
Спасибо вам большое за курс уроков c# c нуля, хотелось бы у вас узнать сколько вы еще планируете выпусть роликов в этом цикле? Спасибо заранее за ответ!
еще 1. ХАХААХАХХ
А сколько всего на сегодняшний день уроков в цикле С# с нуля? 15-ый это все, что есть сегодня?
Все проще. Есть методы экземпляра, есть методы типа. Вся их разница обусловлена именно этим различием. Как только становится доступен тип, доступны и его члены.
Вот и все.
Вы описываете известные факты, но не отвечаете на вопрос почему так сделано. То, что есть static у методов и классов новички замечают почти сразу как только начинают программирование. Только вот почему так сделано им не понятно.
@@SBeregovoyRU Я в целом не против упрощенной подачи, но для меня было намного проще освоить материал о чем-то базовом и важном, а потом оттолкнуться от этого в чем-то более сложном. Давно известный факт, что структурированная подача/прием материала улучшает качество процесса.
И поэтому, для меня, странно рассуждать о статике не имея представления о типах. А имея понимание о сути вопроса, факт2 объясняется сам собой, а то непонятно как язык может защищать от ошибок, особенно когда в студии этим занимается синтаксический анализатор кода)). Такто, в сишарпе есть много вариантов выстрелить себе в ногу, и все они достаточно высокоуровневые..
Ну и таа далее
@@SBeregovoyRUPS может всетаки для чего?))
cпасибо)
Привет. Хотелось бы узнать темы доп видео за спонсорство. Зря отказались от менторства, теме нужно время раскачатьсЯ...
Ухх как у меня подгорало когда почти все примеры в статиках, а я пытался понять и что-то написать в ООП.
Отлично объяснил, Степан! Новичкам зайдет и будет полезно 👍
И всё же что выбрать для helper'а - static или выделить память? Класс helper с методами, которые что-то подсчитывают, сравнивают и т.п. В плане оптимизации памяти стоит ли этот класс вешать как static, если обращаюсь к этим методам только один раз?
Степан, привет! Спасибо огромное!
Добрый день, можно ли наследовать не статический класс со статическим методом?
можно, наличие ключевого слово static не влияет на наследование. С наследование связаны ключевики: abstract, virtual, sealed
Спасибо большое за урок :) Этот урок знал, но смотрел с большим интересом :)
ты обещал мне 150 лет жизни
смотри если помру раньше приду за тобой
Степан, спасибо большое за видео! Я новичок и не использую статики потому что боюсь выстрелить себе в ногу..
Хватит бояться! Пришло время действовать! :-)
Я думал будут комментарии про обиженных сварщиков))
Хорошо выглядишь.
последнее время думал что статик хранится в оперативной памяти и боялся его часто использовать
ну так вообще всё хранится в оперативной памяти после запуска программы
Здравствуйте Степан, хочу спросить если планируете в будущем снимать уроки по WPF и комбинировать с тем что научились в этих видео ? Спасибо из Чехии ;)
WPF не планирую т.к. не мой профиль, я веб разработчик
@@SBeregovoyRU спасибо за ответ а будет продолжение допустим в комбинации с вебом. Просто хотелось бы с консольного программирования перейти на более модерный способ применения С#.
Ничего не поятнооооо опять!😮
Я думаю він Apple.
блин, полчаса, ну одной минуты достаточно, тебе что, делать по жизни нечего
мне кажется это можно было за 10 минут рассказать.
возможно, но у меня свое понимание как и что рассказывать.
Да можно было и за 3 минуты рассказать. Только толку от этого мало для изучения и понимания.
@@SBeregovoyRU Абсолютно правильное понимание!
@@ashimovroman Спасибо за поддержку
Просто есть люди которым хочется всего и побыстрее. А потом начинаются вопросы - "А ПАЧЕМУ ТАК ВСЕ СЛОЖНА??"
Спасибо за урок!
Спасибо, Степан! Отличный урок🙂