
1. Ресурсы:
— https://dotnet.microsoft.com/learn
— https://ru.stackoverflow.com/a/416585/422180
— https://metanit.com
— https://professorweb.ru
2. С# для веб
— https://docs.microsoft.com/ru-ru/aspnet/core
3. C# для десктопа
— https://docs.microsoft.com/ru-ru/dotnet/desktop
4. С# для игр
— https://ru.stackoverflow.com/a/609901/422180
5. С# для мобильной разработки
— https://docs.microsoft.com/ru-ru/dotnet/maui
6. Годные ютуб-каналы
— https://www.youtube.com/c/CODEBLOG
— https://www.youtube.com/c/AndreyShyrokoriadov
— https://www.youtube.com/c/DevJungles
— https://www.youtube.com/user/Shmachilin
Шапка: https://pastebin.com/HT7Hi6FD
Прошлый тред: >>3347352 (OP)
Я прям ждал, что тег при перекате будет проёбан.
Тег csharp, чтобы тред показывался в навигаторе. Модератору отправил просьбу добавить.

1) По существу вопроса >>3395559 → никто не ответил
2) Скочал VS2008 и прочую хрень для разработки для WM6
3) Сдул пыль с книжек: "C# в СССР", "Справочник по .NET для деревенского программиста"
4) Буду ебать тут вам мозг пока не забанят
5) Через пару дней приедет няша с фото
И плюсы есть и шарп

У меня вот такой (пик) где-то валяется. Еще живой должен быть, правда работает только от провода.
Охуенная вещь в свое время (в 2008-м) была.
Программирование мобильных устройств на платформе .NET Compact Framework. Салмре И.
Мне по работке понадобилась бронебойная йоба с excel и инторнетом. Пальцетыкательные штатские телефоны отпали ввиду крайне суровых условий, а этот старичок должен вроде выдержать. По докам держит падение на бетон с 1.5 метров, множественные падения с 0,5 метра.
>>395780
Во! Спасибки! А то я уже и Либген покопал и так гуглил, только на MSDN шлет
Не. А чо это такое?
Пока виртуалка натужно ставит обновы на Вин7. Послезавтра буду VS устанавливать на все деньги.
>Мне по работке понадобилась бронебойная йоба с excel и инторнетом. Пальцетыкательные штатские телефоны отпали ввиду крайне суровых условий, а этот старичок должен вроде выдержать.
Чел, это несерьезно.
Купив эту древнюю "йобу" ты будешь иметь следующее:
1. Дохлый аккумулятор.
2. Крайне хуевый опыт в современном интернете с имеющимися там браузерами. Еще с учетом того, что там старые стандарты wi-fi и сотовой связи. Хорошо если хотя бы 3G будет.
3. Посредственный опыт с excel-ем. Управление стилусом не настолько и удобнее пальцевого, хоть и кажется таким на первый взгляд. Особенно учитывая, что во времена WinCE опыт и практики UX для ручных устройств был такой себе. Ну и опять же устаревшие версии.
4. Крайняя ограниченность ресурсов. Оперативка там измеряется мегабайтами, а современные быстрые sd карточки скорее всего не поддерживаются.
Если же немного покопаться, то можно спокойно взять современный защищенный андроидофон с IP69 и противоударным кропусом за вменяемые деньги. При этом у тебя будет:
1. Нормальный быстрый смарт с хорошим интернетом и связью.
2. Хорошая батарея, которая при активных рабочих задачах вполне спокойно будет несколько дней держать.
3. Нормальные офисные программы с уже вылизанным управлением под пальцы и работу одной рукой.
4. Нормальные ресурсы по железу. Вплоть до того, что ты сможешь полноценную IDE под тот же шарп (причем современный) на нем запустить (то еще извращение, но работает)
5. Есть возможность без особо сильных приседаний удаленно подклчаться к удаленному компу, хоть по ssh, хоть по rdp и делать уже что-то таким образом.
Говорю по собственному опыту, когда лет 5 назад еще работал программистом на производстве. У меня был китайский защищенный ноунейм, который я и на бетонный пол ронял не раз и в станке в СОЖ топил и он спокойно работал. И стоил он по тем временам меньше 10К.
Ну и я умудрялся с него по ssh подключаться к рабочему компу, с которого мого мониторить работу оборудования, заливтаь код и управлять.
>Дохлый аккумулятор.
Съемный. Продаются новые
> хуевый опыт в современном интернете
Мне не нужен современный инторнет. Мне нужен VPN до сети предприятия. Вайфа - 802.11a/b/g
>Посредственный опыт с excel-ем
Мне от него нужна запись пары сотен цифр из базы в шаблон и отправка та комп
>Оперативка там измеряется мегабайтами, а современные быстрые sd карточки скорее всего не поддерживаются.
128Мб, карточки до 32Гб
>спокойно взять современный защищенный андроидофон с IP69
Цена, сестра?! Я три штуки этих, взал за 2500 на Авито.
>Мне нужен VPN до сети предприятия
Ну вот как раз с этим и могут быть проблемы. Я не помню хоть сколько-нибудь хороших клиентов под WinMobile.
>Цена, сестра?! Я три штуки этих, взал за 2500 на Авито.
От 7К. Но в твоем случае соглашусь, как раз этот аргумент может быть самым валидным.
Просто вспоминая себя, когда я работал на производстве, понимаю, что тоже вряд ли мог бы себе тогда позволить лишние траты и тоже тогда приходилось всякое доставать и пердолиться.
почему с# - лучший язык?
C# не лучший язык. Лучшие языки как правило имеют мало применений как раз в следствие своей категоричности.
C# это просто нормальный, относительно нейтральный язык, на котором можно программу написать и она будет деньги приносить

>>Как ни спросишь что-нибудь
>Что тебя интересует?
Ну давай попробуем.
В примерах часто вижу как делегат создают за приделами класса. Зачем так делать, а главное для чего? Что хотят этим добиться?
Выебнулся?
Use PascalCase for class names and method names.
https://learn.microsoft.com/en-us/dotnet/csharp/fundamentals/coding-style/identifier-names
>Аргументация
Аргумент в том, что незачем ходить со своими выебонами в чужой монастырь. Есть официальный и устоявшияся стиль кода который используется 99% процентами разработчиков на нем. И им нахуй не уперлось ломать глаза и голову пытаясь понять зачем и почему ты пишешь по другому.
Ты конечно можешь продолжать выделываться и писать так как тебе хочется, но не удивляйся тогда, что тебя будут сходу посылать нахуй с твоими вопросами. Ну а если решишь где-то работать серьезно, то такой код даже собираться не будет в местных CI/CD.
А дегенерат ты потому, что не понимаешь таких простых вещей.
>Есть официальный и устоявшияся стиль кода
В Visual Studio кликаю мышкой на форму -> создать ивент, студия генерит новую функцию и тут же подчеркивает ошибку формата, надо с большой буквы. Каждый раз ору с этой хуйни нарушающей свои же собственные правила.
Шарписты, какого осознавать, что ваш язык, созданный для того что бы потеснить джаву так и не справился со своей задачей, а вместо него джаву под брюхо пинает какая-то гугловская подделка, в которой нет ООП и даже нормальной обработки ошибок?
> ваш язык, созданный для того что бы потеснить джаву
Где об етом почитать? Или это тебе голоса в голове сказали?
Почитай историю майрософт, конкретно раздел где сказано почему не стали использовать джаву а пошли делать свой язык.
Там прямо так и написано "делаем шарп чтобы потеснить жаву"?
Или все же "просто делаем свой язык причем ТОЛЬКО ПОД ВИНДУ"?
какие принципы инкапсуляции. Этот делегат используется снаружи класса. Так что помещать его внутрь или нет - просто вопрос конечного именования, а не инкапсуляции
In addition to the rules, conventions for identifier names are used throughout the .NET APIs. These conventions provide consistency for names, but the compiler doesn't enforce them. You're free to use different conventions in your projects.
>>396675
>Аргумент в том, что незачем ходить со своими выебонами в чужой монастырь.
А я лично вам ничего и не навязывал, это вы меня тут дегенератом назвали.
>Есть официальный и устоявшияся стиль
Да? А почему тогда int, char, double, string, а не Int, Char, Double, String? Испокон веков названия типов записывались строчными буквами. Так почему теперь я должен писать всё шиворот на выворот? К тому же этот ваш верблюд пиздец как уёбищноВыглядит.
>собираться не будет в местных CI/CD
Это потому что правила там задавали такие как ты?
>продолжать выделываться и писать так как тебе хочется, но не удивляйся тогда, что тебя будут сходу посылать нахуй с твоими вопросами
Хуя тебе сраку на ровном месте распидорасило.
Делегат это ТИП. Логично, что он объявляется где-нибудь вне классов.
С другой стороны, я видел только один пример, где реально нужен был делегат, все остальные случаи покрывает Func<...>, Action<...>, ну или можно автомаппером смапить
Поэтому ты делегат объявишь максимум раза три в жизни, не парься
О НЕЕТ
А разве делегаты это не ооп лямбды, типо как в жяве сигл метод интерфейс? Почему колбеки можно обявить 3 раза в жизни когда макаки их каждый день используют?
мимо не сишорпер
> А разве делегаты это не ооп лямбды, типо как в жяве сигл метод интерфейс?
Нет.
> Почему колбеки можно обявить 3 раза в жизни когда макаки их каждый день используют?
Кто сказал коллбеки? ДЕЛЕГАТЫ. В 99% случаев тебе хватит встроенных делегатов Func<> и Action<>, свои собственные объявлять не понадобится.
Нахуя эта мистификация нужна тогда? Это похоже, но это вам не это? Зачем лишняя сущность делегат тогда? Я сначала подумал что делегат это тип колбека.
https://learn.microsoft.com/ru-ru/dotnet/csharp/programming-guide/delegates/
Делегат — это тип, который представляет ссылки на методы с определенным списком параметров и типом возвращаемого значения. При создании экземпляра делегата этот экземпляр можно связать с любым методом с совместимой сигнатурой и типом возвращаемого значения. Метод можно вызвать (активировать) с помощью экземпляра делегата.
Делегаты используются для передачи методов в качестве аргументов к другим методам. Обработчики событий — это ничто иное, как методы, вызываемые с помощью делегатов.
Какого такого именования? Всё что относится к классу должно быть внутри класса, и по необходимости защищено от внешнего воздействия, а не разбросано где попало, вот и все принципы инкапсуляции.
>>397268
>Делегат это ТИП. Логично, что он объявляется где-нибудь вне классов.
Ну с этой точки зрения да, но всё равно как-то сомнительно.
Ладно, идём далее.
Как я понимаю си решётка это про синтаксический сахарок. Тогда зачем на строчке 3, где, собственно, объявляется делегат, нужно указывать имена входных переменных, те что qqq и www? Они более в тексте нигде не фигурируют, а без них ошибка.
> Нахуя эта мистификация нужна тогда? Это похоже, но это вам не это? Зачем лишняя сущность делегат тогда? Я сначала подумал что делегат это тип колбека.
Потому что 99% случаев - это не 100% случаев. Свои атрибуты тоже надо редко объявлять, и что, они тоже не нужны?
>А разве делегаты это не ооп лямбды
Делегат это тип, который представляет собой ссылку на метод с параметрами метода и с возвращаемым значением.
>Всё что относится к классу должно быть внутри класса
а как оно относится к классу? Покажи где оно используется в классе? Или ты про класс Program? так это вообще entry point
Инкапсуляция же это про "что творится внутри", а не типы прятать. Ты же не жалуешься что внутри себя класс может использовать строки, числа и так далее. Вот как он их там использует и использует ли вообще - это и есть инкапсуляция.
Конечно если делегат снаружи, то его может кто-то и заюзать и потом придется удалять, но для этого есть область видимости как бы.
>>397364
>Нахуя эта мистификация нужна тогда?
делегаты появились раньше дженериков. То есть ДО появления Action<>|Func<>
Однако нужности не лишились, так как обладают именем и могут в ref|out
Когда вызываешь делегат, можешь передать значения аргументов по этим именам.
mydelegate hui = huimethod;
hui(qqq: 123, www: "456");
>нужно указывать имена входных переменных, те что qqq и www
Чтобы автомаппер понимал, к чему маппить параметры
По желанию. Точно так же, как и с вложенными классами.
Если это моя сборка и классы internal, то я могу не хотить плодить длинные имена (ну да с алиасами полегче, но все же)
>В примерах часто вижу как делегат создают за приделами класса
>>397607
>По желанию.
Ну и в чём причина такого желания? Зачем мусорить за пределами класса сигнатурами его методов? Не логично разве внутри объявлять, чтобы было видно чья это сигнатура? Так почему обычно делают наоборот? Какая причина?
>Зачем мусорить за пределами класса сигнатурами его методов?
моя сборка - что хочу, то и делаю. может я не хочу использовать его СНАРУЖИ класса как
new MuSuperPuperClassNameAfterBeerDrink.MySuperShotNameDelegate()
да и вообще - если уж это делегат вызывается СНАРУЖИ класса, то он уже не "внутреннее дело класса". А для раскладывания типов у нас как бы есть неймспейсы.
>что хочу, то и делаю
И в чём причина желания, мотивация какая? Аргументы? И главное, вопрос не про тебя с твоим высосанным их жопы примером, и опять без объяснения мотивации, а причина почему все как правило так делают? Какая причина? Аргументы?
>я не хочу использовать его СНАРУЖИ класса как new MuSuperPuperClassNameAfterBeerDrink.MySuperShotNameDelegate()
Что за детский визг? Почему не хочешь? Такая запись соответствует грамотному программированию - не срать в голобале, а инкапсулировать. Ты против общепринятых практик С#? И не только ты получается, а большинство так пишет, значит программисты на C# против практик которые сами же проповедуют? Так? В чём причины такого неадекватного поведения? Аргументы где? Разумное поведение где? Ты и остальные можете объяснить мотивацию своих действий?
>да и вообще - если уж это делегат вызывается СНАРУЖИ класса
Классы тоже используются вне классов. Так что, классы не нужны? Инкапсуляция не нужна?
>Классы тоже используются вне классов. Так что, классы не нужны? Инкапсуляция не нужна?
Так и классы лежат ВНЕ классов (с) КЭП
>не срать в голобале
каком нахер глобале. есть неймспейсы. не хочешь засирать публичный апи сборки - ну так не делай тип публичным. А если сделал, то слово инкапсуляция тут не причем
ты сначала изучи вопрос что такое инкапсуляция (даже если это на уровне сборки, а не класса), а потом приходи.
Это ты должен пояснять что за моча тебе в голову ударила, что ты тип, который используется СНАРУЖИ класса (как и 1005000000000 других таких же типов), должен помещать в какой то там класс.
Твое "я знаю что он используется снаружи и поэтому хочу поместить его в какой то класс" уже звучит как вызов к психиатру, где даже он удивится и спросит "А ЗАЧЕМ?"

>Такая запись соответствует грамотному программированию - не срать в голобале, а инкапсулировать
Мамку твою инкапсулируем
Чел. Выпей таблетки и изучи что такое инкапсуляция
>Это ты должен пояснять что за моча тебе в голову ударила, что ты тип, который используется СНАРУЖИ класса (как и 1005000000000 других таких же типов), должен помещать в какой то там класс.
Потому что это не самостоятельный тип, а тип принадлежащий классу, это часть класса прибитая к нему своим предназначением. Часть класса должна быть в классе, а не валяться хуй знает где. Мусорить в глобале - противоречит всем практикам и банальному4 здравому смыслу. Объясни откуда это безумие нарушать здравый смысл. ПОЧЕМУ? Почему люди безумны и действуют неадекватно?
>Зачем лишняя сущность делегат тогда
Потому что ты неуч который нихуя не знает про программирование и думает что ссылка на метод это какая-то особенность шарпа. Ты ещё наверное ахуеешь узнав что интерфейс это паттерн, а не ключевое слово в шарпе.
>Это ты должен пояснять что за моча тебе в голову ударила, что ты тип, который используется СНАРУЖИ класса (как и 1005000000000 других таких же типов), должен помещать в какой то там класс.
Я (>>397456) - не он (>>397745 >>397855), но отвечу.
Мало ли что используется снаружи. Я снаружи могу и метод класса вызвать. Значит ли это что я должен метод создавать вне класса?
Да ты и сам говоришь, иле не ты, что
>Конечно если делегат снаружи, то его может кто-то и заюзать и потом придется удалять, но для этого есть область видимости как бы.
Не понятно, что значит удалять и как тебе тут поможет область видимости, привёл бы ты пример, но если кто-то другой заюзает делегат и, скажем, его обнулит, или наоборот, своего натолкает, будет, мягко говоря, не очень хорошо.
>Так и классы лежат ВНЕ классов
А как же вложенные классы?
>Значит ли это что я должен метод создавать вне класса?
А сможешь?
>Не понятно, что значит удалять
это значит что если он в моей сборке, то он помечен как internal (и плевать где он лежит) и меня НЕ ПАРИТ что кто то там его увидит и заюзает, а я потом решу удалить делегат и у него сломается.
А если он таки public, то уже ни о каком сокрытии речь не идет и неважно где он лежит.
>А как же вложенные классы?
в 99.99% случаев они имеют статус private. Но они чисто для удобства чтобы потом самому же и не запутываться. но это ПО ЖЕЛАНИЮ. я могу создать какой нибудь хелпер, но в нем будет дохрена строк и я его отдельно положу.
Сап, поясните ньюфагу плез чем ASP.NET отличается от Blazor-a? Первый это бек а второй фронт или как?
Аспнет - это набор из нескольких технологий, там и кор, и блазор, и мвс, и грпц, и сигналр.
>А чем .NET от .NET framework отличается?
.net framwork - это старые версии, которые еще даже кросс-платформенными не были и работали только под виндой.
тебе в .net (его еще иногда называют дотнет кор). Там всё новенькое, чистенькое и модное
Понял, спасибо, удачи вам товарищи

Долбаебы это те, кто не позволяет отключать компиляцию подобного мусора
Да, согласен, проверки на null очень сильно замедляет работу. Один индус пересобирал core-clr с заинлайнеными статическими проверками на null, и у него общая производительность кода на 50% выросла.
Я сам никогда не пишу проверки на null, а кто пишет - долбоёбы
Только долбоёбы будут это отключать
Раньше пользовался доттрейс - всем устраивало, но сейчас ПРОБЛЕМКИ.
Еще давно пользовался ANTS - тоже отличная штука, но как-то с переходом на кору - перестали им пользоваться и перекатились на доттрейс. А но с ним будут те же проблемки вроде я думаю.
Ломанное на работе ставить низя(
Просто сейчас ищу че ж там загрузку замедляет приложения, и заебался. Когда мелкие данные - ну нихуя не понятно, всегда быстро. Как хуйнул нагрузку большую - так блин, там все вызывается, во всех местах и конукретные хотспоты - ну тяжко находить, а оптимизировать все - ну, ебатина.
где ищешь хоть
Тормозит бд, код дрочить бессмысленно. Вангую у вас там классическое idle in transaction.
Напиши свою метрику, что-нибудь типо юсингов, которые замеряют блок кода, и строят флейм-чарт.
И в коде её и оставь, даже не удаляй
Нет. Как раз БД не тормозит, потому что ее нет)
Вернее как. Это десктоп. Вся "БД" - JSON файлик который при запуске читается, при остановке - схороняется, периодически раз в n-минут создается "резерв" для восстановления если падение будет внезапным.
Тормозит именно логика инициализации там надо в процессе картинки-хуинки подругзить, поубивать всякое что мешает, привести объекты в состояние пригодное для использования и прочая залупистика.
Просто этого много и по всем ходить искать - ну такое.
Говнопидор ты, короче, разбей свой файлик на много маленьких файликов, может он у тебя разросся до сотен мегабайт, а может твоя мать просто снова себя неподобающе вела
Студийный меня бы удовлетворял если бы не падал раз в 5 минут.
Доттрейс раньше я на ночь оставлял смотреть пока всякое гоняется.
Это нужно sql знать, особенно если хочешь компилить с aot, из-за чего не можешь использовать ef core
мимо
SQLite был избыточен.
Нам просто надо дерево объектов хранить между запусками и сохранять настройки с состоянием.
Ну и SQLite - не решит проблему того что мы уже все в память загрузили и теперь бегаем объектики правильно инициализируем.
Говорю же проблема не в том как данные хранятся. JSON за пару миллисекунд парсится, а вот дальше начинается когда данных дофига.
>А потом еще лет 5 доучивается
Бля, вы заебали! Только заказал на Озоне книжку - "SQL за пол дня" и скроллю вакансии Сеньоров по БД, а тут такой облом!
А тебе обязательно весь датасет разом в память выгружать даже с нормальной СУБД вместо файликов? Значит, у тебя где-то проёб в архитектуре твоей проги, переделывай.
Это если тебе надо не загрузить пару записей для десктопного приложения, а ежедневно ебаться с оптимизацией запросов для всяких отчётов. Ты же не забыл, что мы тут не бэкенд обсуждаем?
>Тормозит загрузка жсона по айди?
Давай блядь в БД жсон складывать. Первые 10 раз не тормозит, а когда ты поиск делаешь по 10 форин-кеям - ты охуеешь
Иди на хуй, я лучше нормальные вмеру нормализованные связи сделаю поверх постгре
Да,ты запихнул всё в один JSON, и теперь ебёшься с ним, потому что ты долбоёб. Иди на хуй вообще, я бек пишу и WPF принципиально двухметровой палкой не трогаю потому что вы там одну и ту же проблему по 10 лет решаете и всё решить не можете.
блядь, говнососы тупые, в один поток асинхронно писать не могут, а в многопоток ебуться как слепые щенки
>А тебе обязательно весь датасет разом в память выгружать даже с нормальной СУБД вместо файликов? Значит, у тебя где-то проёб в архитектуре твоей проги, переделывай.
Да обязательно. Потому что за визуал отвечает - ебанат и хочет чтобы ему сразу все дерево объектов отдали. Потому что не захотел реализовывать частичную загрузку, я ему даже показал как - он сказал хуйня, давай мне все разом.
Я-то понимаю что проеб. Я говорил что это проеб. Но тот - рассказывал ЛПРу что я нихуя не понимаю, байты в руках не держал, вообще поколение тиктока и это не веб чтобы подгружать частями, а потому уже ЛПР мне сказал, что делай как он говорит. Я и делаю. Я понимаю что хуйня. Я просто хочу чтобы в моей части не было ботлнеков, и когда его посыпится - на меня свалить уже он не смог.
Десктопная программа с постгресом в зависимостях, лол
При чем тут вообще жсон не жсон? Еще раз - жсон загружается и парсится за пару миллисекунд.
Время уходит на то чтобы всю ебаторию проверить на корректность состояния, поправить если какой-то хуй кривыми руками полез в жсон, правильно всю хуйню сверху инициализировать, привязать одни сущности к другим, подгрузить локализацию, подгрузить картиночки, иконочки, хуеночки, шрифты, и если чел включил автоматическое обновление - проверить нет ли чего и обновить, если при обновлении произошла ошибка или оно несовместимо - откатить. Если при этом что-то пошло не так - найти снепшот того что работало нормально и повторить процесс с тем что было, попробовать при этом подгрузить то что в актуальном и что не подгрузилось - пометить как приводящее к проблеме. Сверху - в самом начале еще до жсона - надо проверить что хуйлан не вносил изменения посчитать хеши-хуеши и попробовать восстановиться скачав правильные файлы обратно. Сверху - проверить лицензию.
Ну серьезно.
Я вообще не понимаю почему разговор про жсон не жсон идет. Я просил посоветовать какой-нибудь годный профайлер, не от жидбрейнсов и ред гейт. Либо что можно купить без больших проблем, либо опенсорсное. Стандартный студийный профайлер - уже в третий раз пишу почему не подходит: эта хуйня стабильно падает при любых сколь-нибудь серьезных проверках производительности.
Видимо придется как дебил брать дотбенч и самому мерить каждый метод. Это тупо, это долго, это надо все методы смотреть и не в реальных условиях а на синтетике. Но раз блин никто не знает - ну, ладно. Видимо ничего в дотнете кроме доттрейса и ANTS нету получается.
>Время уходит на то чтобы всю ебаторию проверить на корректность состояния, поправить если какой-то хуй кривыми руками полез в жсон, правильно всю хуйню сверху инициализировать, привязать одни сущности к другим, подгрузить локализацию, подгрузить картиночки, иконочки, хуеночки, шрифты, и если чел включил автоматическое обновление - проверить нет ли чего и обновить, если при обновлении произошла ошибка или оно несовместимо - откатить. Если при этом что-то пошло не так - найти снепшот того что работало нормально и повторить процесс с тем что было, попробовать при этом подгрузить то что в актуальном и что не подгрузилось - пометить как приводящее к проблеме. Сверху - в самом начале еще до жсона - надо проверить что хуйлан не вносил изменения посчитать хеши-хуеши и попробовать восстановиться скачав правильные файлы обратно. Сверху - проверить лицензию.
А я потом думаю, хуле у меня приложуха погоды в три раза дольше винды загружается, лул.

>Я просил посоветовать какой-нибудь годный профайлер, не от жидбрейнсов и ред гейт.
Да бля, говорю же, пиши сам себе профайлер. У меня такая же хуйня была. Твоя проблема в том, что ты инициализируешь дохуя всего и в очень сложном порядке. Тут тебе никто не поможет
Захуярь скоупы, все подозрительные участки кода заворачивай в них. Один скоуп - один именованный замер времени. Скоупы могут быть вложенные. Суть скоупа - IDisposable. Твой код покроется кучей таких скоупов и тебя будет тянуть блевать от всей этой хуйни, это нормально.
Потом сделай метрику, которая по времени исполнения скоупов генерирует отчёт. В итоге ты получишь что-то типо вложенной метрики:
В общем приложение загружалось 10 секунд
Из них:
5 секунд загружался JSON
5 секунд ебли твою мамку
Ну и соответственно, время, затраченное на твою мамку тоже может дробиться.
Если это не сеть, значит, GC бесоебит. Больше просто нечему тормозить. У тебя джейсончик, возможно, где-то во время проверок строки конкатенируются по 100500 раз. Большой джейсон - большие строки, они уезжают в большую кучу, а потом GC пытается это говно собрать и тормозит.
Ебать, ты диагност телепат, я хуею
>Захуярь скоупы, все подозрительные участки кода заворачивай в них. Один скоуп - один именованный замер времени. Скоупы могут быть вложенные. Суть скоупа - IDisposable.
А можешь ссылку на какой-нибудь пример такого скинуть?
Наверняка есть, но я не знаю. Придётся, скорее всего самому писать.
Да там делов-то на 300 строк кода, через чат-джипити нахуяришь за вечер
... ну вот, например, есть пример https://miniprofiler.com/dotnet/AspDotNetCore , но это для аспнет кора
Вот нужно мне отправлять езернет-кадры в сеть. Недолго думая, езернет -кадр оформил в виде структуры с нужными полями. Но библиотека, через которую происходит отправка кадров, требует массив байтового типа.
Пытался, используя указатели по типу >>3386163 → , перегнать структуру в массив. Ну то есть беру указатель на структуру, привожу его к байтовому типу и далее в цикле переписываю каждый байт. В принципе даже работает, но когда я в структуру, в качестве очередного поля, добавил массив, то резко лосонул тунца - компиляция не проходит. Подозреваю, что это из-за того что массив - ссылочный тип.
Ну и, собственно, как быть? Как структуру перегнать в байтовый массив малой кровью?
>у то есть беру указатель на структуру, привожу его к байтовому тип
охуеешь, когда запустишь на другой машине. дотнет не гарантирует выравнивание и порядок данных в объекте
> Ну и, собственно, как быть? Как структуру перегнать в байтовый массив малой кровью?
сериализовать в абстрактный формат, например, протобаф
Это заранее предвкушают пиратство.
>дотнет не гарантирует выравнивание и порядок данных в объекте
Гарантирует (даже на Auto есть некоторые гарантии), но сам алгоритм в рантайме немного багованный/неэффективный на corner кейсах (где-то в комментах на гитхабе говорилось что-то подобное с примерами):
StructLayout.Sequential +
https://learn.microsoft.com/en-us/dotnet/api/system.runtime.interopservices.structlayoutattribute.pack#remarks
>>400943
>Ну то есть беру указатель на структуру, привожу его к байтовому типу и далее в цикле переписываю каждый байт.
Может лучше MemoryMarshal.Read/Write?
>но когда я в структуру, в качестве очередного поля, добавил массив, то резко лосонул тунца - компиляция не проходит. Подозреваю, что это из-за того что массив - ссылочный тип.
fixed-size buffer или InlineArray:
https://learn.microsoft.com/en-us/dotnet/csharp/language-reference/unsafe-code#fixed-size-buffers
https://learn.microsoft.com/en-us/dotnet/api/system.runtime.compilerservices.inlinearrayattribute
Создаю в классе свойство
public string жопа { get; private set; }
Всё норм - снаружи изменить не могу. Но как только я делая массив
public string [] жопа { get; private set; }
так получаю полный доступ.
>так получаю полный доступ.
Ты получаешь доступ только к содержимому массива. Сам массив ты заменить на другой не сможешь. Если ты хочешь, чтобы и содержимое снаружи нельзя было изменить, то отдавай IReadOnlyCollection<string>.
>дотнет не гарантирует выравнивание и порядок данных в объекте
>>401673
>...
Хотя хуй его знает, если поискать issue связанные с лэйаутом, то их пиздец как много. LayoutKind.Sequential вроде влияет на managed структуру если тип blittable (т.е. даже unmanaged недостаточно). Хотя много кода полагается на то что если структура unmanaged, то поля будут последовательно (с паддингами если нужно; если LayoutKind.Auto не стоит), так что вряд ли они будут этот момент менять (да и смысл). Можно конечно в dotnet/runtime спросить.
Просто к сведению:
https://github.com/dotnet/runtime/discussions/94481#discussioncomment-7502637
нет там никакого здравого смысла. просто не продумывали. Так же как и с IReadOnlyList
Попробуй вместо массива ссылку на объект. Поля этого объекта по-твоему тоже должны стать приватными что ли?
вообще не понял что ты сказал.
В шарпе вместо того чтобы все сделать сразу - мутабельные, иммутабельные, фрозен/ридонли и соответственно с интерфейсами сделать, сделали абы как. И это просто факт.
Вот и иди нахуй отсюда.
Чтобы можно было менять элементы массива извне при неизменности ссылки на массив. Да и как массив должен догадаться, что где-то в чужом коде для него написан приватный сеттер?
>Чтобы можно было менять элементы массива извне при неизменности ссылки на массив.
Но тогда я могу поэлементно заменить массив и добиться того же самого как если бы подменил массив разом. Дырявая какая-то защита.
У интовой переменной я вот не могу изменить содержимое, так почему у массива могу? Где логика?
>Да и как массив должен догадаться, что где-то в чужом коде для него написан приватный сеттер?
Почему в чужом? Всё ж в одной строчке пишется.
public string [] жопа { get; private set; }
>так почему у массива могу? Где логика?
потому что массив мутабельная коллекция. ты выставляешь наружу мутабельную коллекцию - ну значит ее содержимое могут изменять. Но не смогут заменить саму коллекцию, то есть ссылку на нее.
Выставляй наружу ридонли. Таких правда нет чтобы массив, но ты знал куда пришел.
> Но тогда я могу поэлементно заменить массив и добиться того же самого как если бы подменил массив разом.
Нет, не того же самого. Ссылка осталась старая, и это фича. Методы, которые на это полагаются, так и продолжат работать. Не придётся заменять ссылку на массив в других классах, которые могут этот массив использовать, изменил значения элементов массива в одном месте - и они изменились сразу везде. Без такой фичи пришлось бы везде таскать делегат для геттера.
> Дырявая какая-то защита.
Это не защита, а специально так сделано, чтобы специально можно было заменить все значения элементов массива.
> У интовой переменной я вот не могу изменить содержимое, так почему у массива могу?
Потому что это разные вещи. Как не можешь изменить интовую переменную, так и ссылку на массив не можешь, но на элементы массива это не распространяется. Потому что массив и ссылка на массив - не одно и то же. Сеттер для ссылки на массив ты сделал приватным, но сеттер элементов массива ты не трогал, он как был публичным, так и остался.
> Почему в чужом? Всё ж в одной строчке пишется.
Не вижу в этой строчке внутренней реализации массива, вижу только её использование каким-то чужим кодом, о котором реализация массива ничего не знает.
мне всё равно заняться нечем
>>401873
Ну может такое поведение и можно объяснить тем что массив - ссылочный тип, его содержимое как бы оторвано от имени. Но всё равно выглядит странным, если мне надо защитить массив, то мне надо защитить его полностью.
>Без такой фичи пришлось бы везде таскать делегат для геттера.
Тут твоя мысль от меня ускользает. Ну и ладно.
>но сеттер элементов массива ты не трогал
А такие есть? Для каждого элемента можно сделать свой?
>Таких правда нет чтобы массив, но ты знал куда пришел.
Потому что - не нужно. Там где нужны массивы, похуй на ООП шелуху, а там где есть ООП - похуй на массивы, достаточно коллекций.
> ООП
Лол, я бы посмотрел на код, где картинки обрабатывают в виде IReadOnlyCollection<IReadOnlyCollection<Color>>
>где картинки обрабатывают
Ну так ты сам и ответил. Какое тебе там ООП, безопасность и модификаторы доступа при обработке графики. Ты будешь там хуярить с отключением проверок границ массивов и прочим ансейфом, чтобы нормальной скорости добиться и тебя вообще не будет ебать - private set там public или что-то другое.
технически ты прав, но ситуация с Ilist говорит о том, что хрен кто вообще задумывался о какой то там ридонлистости, а больше "и так сойдет"
ты о чем? я всегда обсирал коллекции шарпа во всех тредах.
Видишь кто то бочку катит на коллекции (да и на прочие WTF шарпа) - 99% это я.
>Видишь кто то бочку катит на коллекции - 99% это я.
Долбоёб, не разобрался с коллекциями.
Тут еще невдупляшка был, который не понял, как IDisposable пользоваться
Ну хoxлoв тут тоже не надо. Я как-то работал с ними в одной кипорской компании, так они мало того, что нихуя не понимают, так еще и ленивые как пиздец
>Долбоёб, не разобрался с коллекциями.
> IDisposable пользоваться
я и есть тот, кто продвигает лайфтаймы
но тебя я тоже помню - любое ГОВНО оправдаешь как "ты не распробовал"
спасибо, но говно всегда говно, можно хоть миллион раз его попробовать, но вкус все равно останется таким же и ценителем я не стану.
если с коллекциями все шикарно изначально, то нахрена ПОТОМ появились иммутабельные, а потом и фрозен? риторический вопрос.
>если с коллекциями все шикарно изначально, то нахрена ПОТОМ появились иммутабельные, а потом и фрозен? риторический вопрос.
В смысле риторический? МС пошло в сторону ФП причем давно, что бы не ебаццо с синхронризацией (все эти асинки, иммутабельность и прочее). Какому нибудь серваку на азуре пох на неэффективность, у него 1000 железных ядер, главное что бы не падало и не зависало из-за ошибки с синхронизацией потоков.
А чистые массивы из первой версии CLR, это конец 90-х.
а зачем IReadOnlyList?
>я и есть тот
Ясно, один и тот же долбоёб жалется на коллекции и IDisposable.
>кто продвигает лайфтаймы
мусор не нужен
не жалуюсь, а тыкаю в очевидные недостатки.
Но что я могу пояснить говноеду - он уже привык жрать и радоваться.
2 года назад прошел и получил оффер 190к + премии = 220к на руки на .NET/T-SQL разраба.
>мусор не нужен
смотря где
ты правильно говорил "диспозе всего лишь метод". То есть диспозабле паттерн говорит "будет такой метод и его НАДО вызвать и тем самым произойдет очистка". ВСЕ.
Вот и вся навука про "как его использовать". Тут нет НИЧЕГО про то как его вызывать вовремя и не забывать.
Эту проблему решают другие средства типа контейнеров. И если в асп.нет у тебя есть контейнер, скоупы которого можно натянуть на диспозабле, то в десктопе у тебя есть НИХУЯ (огнетушитель тем, кто попытается это решить контейнером)
Поверь, довольно сложно правильно использовать НИХУЯ. Как то не очень получается и приходится городить огород. И лайфтаймы - самый удобный и крутой огород.

>Тут нет НИЧЕГО про то как его вызывать вовремя и не забывать.
Ты так нихуя и не понял
>Эту проблему решают другие средства типа контейнеров.
При чём тут контейнер вообще? Ты еблан?
>И лайфтаймы - самый удобный и крутой огород.
Сука, ебучий коммивояжёр, блядь
>При чём тут контейнер вообще? Ты еблан?
При том что диспозе не заканчивается на тупом using(var disposable =
и контейнер в асп.нет коре рождает и убивает все диспозабле которые scoped при каждом запросе.
Учи матчасть, понимака.
Есть вакансии для джунов? Как с фрилансом?
Знаю СИ, но я так понимаю, никакой связи с ним нету.
>Знаю СИ
Если твоя мамка не против, если ты имеешь опыт коммерческой разработки и если обещаешь не байтоёбствовать - то да.
Если ты мудак, которые будет всех учить, что нужно экономить пол байта оперативки, и который простреливает себе жопу через каждые 12 минут - то, пожалуйста, оставь эту затею
>Подходит ли c# для вката жука-плавунца 35 лвл?
Если сможешь полюбить Иисуса ООП и впустить его в себя - то вполне.
>Есть вакансии для джунов?
Мало, но есть. Будь готов, что на собесе тебя будут попускать по кишочкам по полной программе.
>Как с фрилансом?
Фриланс мертв сам по себе, а на шарпе его и не было особо. Сейчас только по знакомству, если тебя кто из-знакомых на какой-нибудь аутсорсный проект позовет, чтобы на подхвате быть.
>Как с фрилансом?
Бля, ты такие вопросы задаёшь. Фриланс по определению ГЛОБАЛЬНЫЙ рынок. Потому он и называется ФРИ ЛАНС. Вся идея, что можно сидеть где-нибудь в Бангладеше и при этом находить клиента из Германии. Во фрилансе есть любая работа, на любом языке и на любом стеке. Кроме непосредственной работы с паяльником/лобзиком/станком и так далее. То есть на фрилансе нет только той работы где надо непосредственно сидеть в офисе/рабочем месте.
>Есть вакансии для джунов?
ВАКАНСИИ ДЛЯ ДЖУНОВ - это всегда 1-5% вакансий на рынке. До пизды какой стек. C#, java, python, ruby, C++, rust, и так далее. Возьми общее количество вакансий, ну например 2000 вакансий. Посчитай 1-5% от этого числа. И ты получишь общее количество вакансий для джунов. При этом, на этот 1% стремиться попасть 50% программистов. У них логика такая: ну и что, что там мало платят? Я не жадный. Мне много на жизнь не надо. 30к в месяц хватит. Посижу годик попержу, потом съебусь на сладкое место. В итоге он приходит, а там уже очередь из сотни человек таких же "мне много не надо, я пришёл за опытом". Он делает скриншот и идёт на двач, закатывает там истерику ПОМОЖИТЕ ЛЮДИ ДОБРЫЕ НИГДЕ НЕ БЕРУТ, ВХОД ВАЙТИ ЗАКРЫТ. В итоге жалобы, вопросы ШО ДЕЛАТЬ? Ну и так далее.
все так, добавлю статистики
согласно данным на hh на сегодня на одну вакансию:
Python - 50 резюме.
C#/Java - 35
C++ - 25
в золотые ковидные годы в среднем был 10 рез/вак.
вообщем мне кажется hh.ru превратилось в помойку и убито HR-ми
которые ставят ЗП - 250к, едешь на собеседование, смотришь, а там уже 150к.
вот нахуя там делать...
какие есть альтернативы hh?
>ВАКАНСИИ ДЛЯ ДЖУНОВ - это всегда 1-5% вакансий на рынке. До пизды какой стек. C#, java, python, ruby, C++, rust, и так далее
Большая конкуренция на рынке именно среди стажеров и джунов без опыта. Там резня, да.
Но в целом многие крупные конторы сейчас склонны нанимать микрочеликов студентов с 1-3 годами опыта, а не сеньоров 10+ лет стажа. Просто потому что микрочелики дешевые и неплохо перформят, а сеньки очень дорогие и часто не оправдывают своих ожиданий.
У нас вот в команду сеньку взяли в конце прошлого года. Прошло вот уже почти 3 месяца. Но толку от него особого нет. Код пишет местами хуже, чем наши стажеры, которых мы на постоянную ставку джуна переводим. Какой-то топ экспертизы от него тоже не видно. Объективно очень средний челик, максимум мидл, не более того. Но зп у него сеньорская. И зачем таких нанимать, когда есть более молодые кандидаты, которые перформят так же, но стоят сильно дешевле?
Но тут важно отметить, что у нас стажировок довольно много, берем к себе умную студентоту из мфти и вшэ, всяких зумеров с явно выраженным свдг и low iq нормисов оставляем за бортом. И сами по себе мы не мухосранская галера, а бигтех на несколько разрабов.
описал типикал бигтех галеру
где каждые пол года вводят ебанутые правила, тренниги, корпоративная этика, планерки, рутина.
тут что кому по душе, я в таких работать не могу, пусть даже и зп там в среднем выше.
мой выбор что-то среднее между НИИ и бигтех-галлерой
Какой хороший гой, переживает за деньги кабана.
Во-первых, какой-нибудь абсолютно бесполезный скрам-мастер получает даже больше сеньки, а делает нихуя. Отдел HR можно разогнать весь к хуям, оставить одну девочку оформлять трудовые.
Во-вторых, чем больше кода, тем дольше происходит вкатывание в этот код. Майкрософт не просто так доплачивает своим сотрудникам за стаж. Три месяца - это вообще ни о чем, в большом легаси только через полгода можно ожидать от чела самостоятельной работы. Говорю по личному опыту лида в продукте с 20-летней историей.
В-третьих, разговоры о качестве кода выдают в тебе джуна, который прод не нюхал. Код или работает или нет, это единственное качество, остальное инфоциганство от мартина.
>какие есть альтернативы hh?
В РФ - практически никаких. hh потому и скатились, что они уже лет 10 назад полностью выдавили всех конкурентов из интернета и могут творить что хотят. Из альтернатив только личный нетворкинг и может быть еще какие-нибудь ТГ каналы. Ну и напрямую искать сайты работодателей и долбиться к ним лично.
Прочитал что mssql по какой-то причине такое не поддерживает.
У меня сущности: Result <- User <- Group.
И я хочу чтобы при удалении группы удалялись юзвери и следовательно если удаляется юзер - удалять его результаты.
Пока что единственный вариант что я вижу - это на стороне базы сделать триггер на удаление.
Я реально не понимаю почему это не поддерживается в mssql?
Походу так и сделаю.
>Написать хранимку, которая удалит все за один поход в бд - не хочу.
>Дрочить бд, отправляя запросы в цикле - заебись идея!
Бекенд разработка в 2025 году.
>Прочитал что mssql по какой-то причине такое не поддерживает.
DELETE CASCADE не поддерживает?
не может такого быть
не, я походу долбоеб, найти не могу. раньше все находил терь ваще не могу ладно похуй. спс за попытку помочь
Если в райдере, то шифт шифт и il пишешь.
Ты сам себе злой буратино который выбирает неподходящий инструмент.
Ещё раз. Все эти штуки в С# нужны для взаимодействия с кодом на С/С++ или иных подобных задач.

>GetAddressOf()
>на переменную в классе
Я так понимаю у тебя там "ComPtr<ID3D11Device> _d3d11Device", и ты вызываешь GetAddressOf() на ней, да? Вот только GetAddressOf() возвращает указатель на саму переменную, если я правильно понял, это же будет опасно (GC подвинет), не? Ну и про остальные переменные тоже самое.
В прошлом треде об этом говорили, но в итоге не привели доказательств этому.
Чем, например, asp.net core лучше спринга?
Оба языка аналогичны по возможностям, разве что в шарпе синтаксис поприятнее. Васянских библиотек везде полно, но на то они и васянские, что нормальные люди их использовать не будут. Аргументов лучше личных предпочтений ты не услышишь, если бы было что-то серьёзное, выбор был бы очевиден, и на одном из языков просто никто бы не писал.
Мне человек, который работал на джаве, говорил, что в джаве много популярных библиотек, которые решают одну и ту же задачу. Из-за этого приходится знать их все, когда в шарпе есть универсальные решения, аля ef core, masstransit и етс, и многие из них разрабатываются самими мелкомягкими. Еще он говорил про проблемы с версионированием.
На джаве больше вакансий.
За джаву больше платят.
На джаве значительно меньше фулстек параши с аутстаф галер. В сишарпе с этим просто беда, микрософт целенаправленно превращают дотнет в нодежс для дебилов. После ухода Гейтса все покатилось в пизду.
В джаве надо знать спринг и суметь пояснить за канкаренси на собесе, реактом и кубером занимаются другие люди. В сишарпе почитай требования на типичную вакансию, ты охуеешь (потом сравни зп и охуеешь во второй раз).
На джаве куча вакансий на продукт, а не на финтех говно проект 3 месяца.

Имеет смысл залетать на миддла с пет проектами без опыта коммерческой работы? (пукать в офисе)
Какого вида вообще пет проекты надо иметь если вкатываешься в бэк на сишарпе? Рестфул хуйню любой может написать и я не думаю что кого-то это впечатлит.
Сервис бронирования или электронную очередь.
Как перекатиться с wpf на java spring? Сейчас получаю 130к и понимаю, что для впф это почти потолок
>Оба языка аналогичны по возможностям, разве что в шарпе синтаксис поприятнее.
Ага, давай сравнивать заплесневелый javaspring, где закаменели худшие ООП практики: вся эта ебала с АОП, XML код вперемешку с java, DDD, встроенный в DI контейнер... с новеньким aspnet-кором, который уже 10 лет причёсывают и упрощают?

Суть. На текущем проекте ебанутый кодстайл.
Я, не люблю со своим уставом в чужой монастырь ходить.
Но я не хочу ручками выравнивать.
Приложу пример стиля.
Было бы славно если бы сказали в какую сторону копать.
.editorconfig
>>403054
А что, собственно, с фрилансом? Что на Java, что на C# ситуация одинаковая. В РФ есть аутстафф-галеры, которые устраивают тебя к себе самозанятым и находят временные проекты сроком примерно на полгода. Я так работаю с начала ковида. Много не заработаешь, но на еду хватает (а больших денег во фрилансе, собственно, и не бывает). Можно сидеть дома и не надо мониторить вакансии самому. На глобальном рынке жителей РФ и Украины не нанимают, к тому же есть гораздо более дешевые индусы (а большой потребности во фрилансерах нет).
>Из альтернатив только личный нетворкинг
Наилучший вариант, но это исключительно для сеньоров с 10+ годами стажа. Для остальных только hh.ru и career.habr.com.
>Ну и напрямую искать сайты работодателей и долбиться к ним лично.
Крупным IT-компаниям (Яндекс, ВК, Сбер и т.д.) такое не нужно, и ответа не будет. А вот галерам можно писать, они ищут работников для проектов. После ухода EPAM и Luxoft, например, можно в i-teco.ru (они работают исключительно на российском рынке).
>Я, не люблю со своим уставом в чужой монастырь ходить.
Такое говно вижу впервые, и оно вызывает у меня грусть, потому что его скорее всего придумал человек, который очень мало c# кода читал. Более того, он мудак и раскольник.
Если автоформатирование не работает - просто игнорируй эту хуету.
>который очень мало c# кода читал
либо сторонник лимита в 80 символов.
типа так diff проще и на мобилах читать проще и вообще.
>true == b is 0
Это какой-то отбитый сишник писал, не иначе. Я даже не могу представить, под какими веществами можно родить эту конструкцию.
Да под С# какие могут быть платные проги? Сижу на linux, net core позволяет, студию не ставил, в vscode сейчас все плагинами решается, накрайняк vscodium, vim, zed. Базы данных в основном PostgreSQL, MySQL. Ну может только Azure - вот тут да. Надо искать альтернативу.
>либо
ну и пусть сам ебётся. Есть рекомендации от микрософт, общепринятые стандарты. Игнорировать их - себе жизнь усложнять
Работаю в банке. На рабочей машине стоит VS2022 с энтерпрайз ключом от работодателя. Ключи покупались конторой где-то в 23-м году, когда их типа нельзя было уже купить. На своей тачке так же пользуюсь VS2022 комьюнити эдишен. Брат жив, зависимость есть.
Вот райдер купить или еще какие приблуды от жидбрейнсов - это уже хуй.
Ну и VSCode естественно, но она в основном для работы со всякой мелочью типа конфигов, js-а и местного ИИ.
Хуй знает, не слежу за ним, в прошлом году вроде еще платным был. Решарпер точно все еще платный.
>не для коммерческого использования.
Так ты на нём и не занимайся коммерческой деятельностью
>Интерактивные приложения Blazor на стороне клиента
>Применяйте в разработке взаимозаменяемые компоненты пользовательского интерфейса, обеспечивающие производительность практически на уровне внутренних компонентов браузера за счет WebAssembly.
Что значит производительность на уровне внутренних компонентов браузера? Т.е. скорость открытия всяких браузерных менюшек? Т.е. быстрее чем фронт написанный на жс?
Производительность на уровне внутренних компонентов браузера означает, что Blazor WebAssembly может работать с такой же эффективностью, как и нативные операции браузера (например, рендеринг страницы), Быстрее, чем традиционные приложения на JavaScript, в некоторых случаях, когда речь идет о сложных вычислениях или обработке данных.
>Т.е. быстрее чем фронт написанный на жс?
В теории да - там неонка wasm внутре. Но очень многое зависит от твоих кривых рук.
>проблем вроде нет
А так всегда бывает. Проблем нет пока они не начнутся.
Я вот планирую жить вечно и пока удается.
Это значит, что с блазором мартышке не надо понимать, как работает сеть. Где рякт отправит один джейсон в конце, приложение на блазоре будет дергать бекенд на каждый пук на форме. Ну а че, на локалхосте все работает быстро.
1. C# для чайников Автор книги – Джон Пол Мюллер
2. Программирование на C# для начинающих 2е части Автор: Алексей Васильев
3. Head First. Изучаем C# 4е издание Авторы: Эндрю Стиллмен, Дженнифер Грин

864x1920, 0:12
Ой бля из-за одной сраной книги сейчас будет консилиум собирать, я просто заказываю пачку книг и не парюсь, завтра должны 10 книг привезти и я представь себе не консультировался с двачем по этому поводу.
А как ты поймёшь, в каком порядке будешь их читать? Подбросишь десятигранник?
Сам писал так долго.
К чему приводит. Обычно - сервис все равно нигде кроме одного контроллера не используется. При этом - если еще и интерфейсы вынесены - ты просто f12 нажать чтобы перейти не можешь, надо ctrl+f12, не большая проблема, пока вы вдруг тесты не начали писать или кодген какой-то не подрубили.
Вообще. Чет у меня кажется кризис среднего возраста. 10 лет пишу и типа чем дальше, тем больше все что там писал - кажется каким-то карго культом. Ну, вынес я интерфейсы, ну, делаю я сервисы отдельно. Че дает? Дает то что вместо того чтобы за 10 секунд поправить в контроллере, я иду в контроллер, ищу что ж там за сервис для апишки вызывается, иду ищу где ж там сервис такой. Потом вспоминаю, что я решил что и сервис будет точкой входа, а дальше он в CQRS начнет оборачивать и через медиатор дернет хендлер. Ищу хендлер. Нахожу хендлер где-то запрятан в глубинах. Таки нашел. Поправил. Забыл через секунду все это и в следующий раз то же самое проделывать буду.
Не. Ну справедливости ради - иногда было полезно, когда оказывалось что надо добавить апишку похожую, но в другом контроллере с другими способами проверки прав, и чутька другой обработкой, там таки да - о, у нас же уже в сервис вынесено - просто перенаправим в него. Но в большинстве случаев чет жижей сейчас кажется.
Короче. Я не знаю. Чувство что я большую часть карьеры какой-то надуманной хуйней занимался. Скажите что-нибудь хорошее про медиаторы, CQRS и прочее, чтобы мне легче стало и я просто перестал об этой хуйне думать.
Ну возьми вынеси абсолютно всю логику в контроллеры (да хотя бы даже не всю, а только бизнес, без DAL) и поработай так месяцок.
Вот когда ты охуеешь эти портянки править и внедрять в них что-то новое, тогда и поймешь зачем это. Особенно когда тебе не одна, а несколко смежных задач прилетает. Ну или не только тебе, а когда приходится еще с кем-то в команде над смежным функционалом и вам потом приходится пару дней сидеть и резолвить конфликты.
Смысл не порядке, а в просто чтении. Никак я не выбираю порядок. В зависимости от настроения беру понравившуюся. Если слишком занудная или сложная то откладываю. Беру книгу если еду в поезде или транспорте или стою в очереди. Если поезд, то могу страниц 200-300 прочесть. Если общественный транспорт страниц 10-15 в одну сторону и столько же в другую. Из технической литературы читаю про duckdb, нейронки и архитектуру и проектирование апи. Вот в принципе и всё.
>Скажите что-нибудь хорошее про медиаторы, CQRS и прочее
Про медиатр ничего хорошего сказать не могу, это мусор. Гораздо проще писать CQS заебали путать cqs и cqrs без этой хуйни.
Просто заинжекти команду или квери и исполни её
Медиатор, ещё раз повторюсь, это мусор, который просто навигацию по коду превращает в болото. А если скомбинировать с автомаппером - получается ад.
>тогда и поймешь зачем это
Не подменяй понятия. Выносить логику из контроллеров это хорошо. Медиатр это плохо
читаешь все подряд в любом порядке. читаешь чужой код в любом порядке. Раньше для этого требовался хоть какой то "понимаю в общих чертах". А сейчас можно спросить у ИИ "что тут вообще блин происходит". И даже простая гптмини тебе разжует и в рот положит.
>контроллер
Задача контроллера - валидировать вход и логировать выход. В аспнете это все делается из коробки, так что контроллер литерали нужен, чтобы пробросить данные дальше в бизнес логику.
>медиаторы
Нахуй не нужен этот паджит стайл. Используй саги.
>CQRS
Это про инфраструктуру, а не про код. Пишем в мастер базу, читаем с реплик, тем самым масштабируем систему на чтение. Задача для девопса.
>сервис будет точкой входа, а дальше он в CQRS начнет оборачивать и через медиатор дернет хендлер
Чтобы что? Логика вызова микросервисов должна быть в саге, сам микросервис про другие ничего не знает.
Короче, ты наворотил абстрактных абстракций, а теперь удивляешься. Чем проще - тем надежнее.
И сколько из них ты прочтешь интересно?
>саги
>просто
>надежно
У тебя в проекте этого быть не должно. Любые попытки сделать распределение транзакции это ошибка проектирования системы.
потому что они не нужны.
Если такой дохуя умник, расскажи как у тебя саги устроены? Я без шуток, никак это знание древних протоереев освоить не могу
Саги изначально призваны решать проблему которая появляется от кривых мозгов. Если у тебя два разных сервиса должны атомарно что-то сделать и необходимо откатить А при падение Б, то
1) на самом деле операции А и Б могут быть независимы и атомарность ты сам придумал.
2) на самом деле они должны быть просто в согласованы в периоде времени N. То есть буквально делаешь события.
3) ты неверно провел декомпозицию сервисов. Необходимо объединить все сервисы что участвуют в транзакции в один.
Сервис Б пишет другая команда. Твои действия?
Как ты собираешься делать перевод денег без атомарности?
Сервисы объединить невозможно потому, что данные физически лежат на разных шардах в разных базах. Надо передать данные от шарда А к шарду Б и откатить, если что-то пошло не так. Как будешь решать эту задачу без саги? Размазывать код тонким слоем говна по 100500 медиаторам?
О, вы из епама!
Сага - это отдельный сервис, одна сага на каждую бизнес транзакцию. Это одна строка в бд и один конечный автомат в коде. По сути тот же аутбокс, только для N сервисов. Вся логика откатов и ретраев находится в одном файле, логику легко понять и покрыть юнит-тестами. Никакого ебаного месива из медиаторов, весь код в одном месте. Если сага застряла, ты просто правишь данные в бд и руками перекатываешь ее куда надо. Если для эксперимента надо сагу немного изменить, ты просто копируешь один файл и запускаешь рядом новую сагу, старая работает как раньше.
Из минусов - для саги нужен девопс все настроить. Поскольку в аутстаф галерах дейплой происходит мышкой через админку, для них саги это сложна нипанятна лучше пукнем джейсоном в очередь.
>Никакого ебаного месива из медиаторов
Не понимаю, нахуя вы пишите про медиатры вообще? Они же никак не влияют на кодовую базу кроме как попытка заменить DI, и
>Они же никак не влияют на кодовую базу кроме как попытка заменить DI
в каком месте они заменяют DI? они на нем и базируются
Они (да почему они то) призваны разделить запросы и обработчики, попутно унифицируя выбор хендлера и имея возможность вмешаться в процесс обработки.
Получается относительная гибкость, но за это платишь неявностью и приседаниями.
А когда от приседаний начинают болеть коленки, то тогда челы приходят на двач и начинают лить каки (и заслужено) на медиатры.
Мы точно говорим про одно и то же?
Медиатор - это сервис, который выгребает ивенты из кафки. Юзер сервис пукнул в кафку джейсоном "user created", медиатор занюхал и дальше вызвал сервис емейлов "отправить письмо". Или поменял статус в сервисе интеграции. Или еще сделал какую хуйню, в зависимости что нам надо в этой конкретной бизнес транзакции.
Если ты про библиотеку Mediatr, с помощью которой шизы на архитекторе пытаются имитировать работу по сети внутри локального процесса, то это запредельный пиздец и рак мозга.
>в каком месте они заменяют DI? они на нем и базируются
Ну вот я прямо видел такое несколько раз. Выкидывают DI и переписывают на медиатр-автомаппер. На вопрос, "а нахуя?", обычно говорят, что так можно валидировать входные параметры методов.
В итоге каша получается без слоёв, без структуры. 🤮
> В чем проблема использования медиатра
В том что решает ровно ноль проблем, но при этом навигация по коду усложняется.
Ничего. Всегда так делаю.
Я в дескотопе, есть команды от юзера, есть хендлеры, которые их исполняют, есть разные политики исполнения, разные контексты и т.д. Вместо медиатра какая то своя реализация, но принципиальных отличий не вижу, вокруг него вроде бы все тоже самое можно накрутить.
Что такое команды от юзера? Ивенты OnButtonClick? Так они нужны только для биндинга. Как только исполнение дошло до контроллера, дальше спокойно вызываешь методы без пердолинга с шиной.
Мы используем концепцию скриптов. Это литерали то же самое, что сага в облаке, только на десктопе. Надо тебе допустим сделать выгрузку в эксель, во вьюмодели в обработчике Export просто вызывается _script.Run(data) где _script это IExportToExcelScript инжектится через DI. Навигация по коду работает, в отличие от шины событий.
Проблема в том, что когда у тебя обычные вызовы методов, ты можешь с Ctrl проклинать или делать find all references, а когда у тебя ивент брокер, тебе надо сидеть и смотреть, как там ивенты называются и пр.
И если с обычным di и вызовом методов ты можешь построить граф зависимостей, то с ивент брокером это совершенно невозможно, никто не сможет через полгода в этом спагетти разобраться, а это обязательно приводит к багам.
Явное > неявное.
Я конкретно с медиатором не работал, но мне несколько раз доставался код с ивент басами на овощных разных языках, и оно везде только мешало и было нахер не нужно.
Так что я могу со всей ответственностью заявить, что это антипаттерн.
Ну когда у тебя есть шина сообщений ты можешь пукнуть сообщение и все его обработки будут вызваны.
Добавление нового не требует создания новых методов сервиса или добавления 100500 вызовы медиатора. Ты просто пишешь новый обработчик.
Ты в любом случае правишь код. Почему нельзя просто вызвать метод напрямую, а не через шину?
Хуже. С шиной сообщения размазываются слои приложения, и начинается пиздец, когда кусок кода вызывается или не вызывается в зависимости от ряда косвенных признаков из неизвестно откуда. Приложение становится разнонаправленным, теряет всякую свою организацию и превращается в ад.
Куда размазываются. У тебя в Application слое должны лежать все обработчики и там же находится объявления событий и там же лежать сервис который пукает сообщения из очередей к тебе.
Все твои вызовы шины должны также находится внутри Application потому что это слой где лежит ВСЯ логика приложения.
Видел проект, в котором команды и хендлеры лежали во всех слоях.
А знаешь, почему? Потому что там, например, была команда-репозиторий, которая возвращала IQueryable, и лежала в ДОМЕНЕ, а в домене она лежала потому что Ентити-фреймворк удобнее в домене держать.
Я после двух месяцев созерцания переписывания сервиса с 5000 строк на медиатр+автомаппер на 50 000 строк, я уволился одним днём.
То есть, буквально, был сервис, который в одну сторону перекачивает данные из сторонней апишки в БД, а стал ГЕКСАГОНАЛЬНЫЙ ДОМЕН-ДРИВЕН СQRS, где обязательно нужно писать валидаторы с проверками на нулл входящих параметров потому что все команды маппятся автомаппером, и просто никто не знает, может там быть нулл или нет.
Сука, как же у меня тогда жопа пригорела. И ведь это был второй раз, когда медиатром буквально на ровном месте сделали месиво.
Первый раз был когда на проект с действительно большими проблемами (PolicyOne) наняли О, АРХИТЕКТОРА, который вместо того, чтобы упрощать рекурсивную зубодробительную логику, начал пытаться переписывать всё на автомаппер+медиатр. Переписывание заняло пол года, в которые я искал новый проект, а когда я уволился - начались массовые увольнения, потому что ОЙ.
Короче, пацаны, я с полной уверенностью заявляю, что подключение медиатра - это всегда дьявольщина.
Скоро не нужен будет. Нейронки будут по одному большому промту сразу в двоичный код хуярить и всё. Программисты пойдут на хуй как и добрая часть ит
ты просто хреновый программист поэтому ЗАВИСТЬ )
Программистам ХАНА уже через ГОД — об этом абсолютно серьезно заявил CEO Anthropic и создатель Claude, Дарио Амодей.
заявление для дурачков )
Потому что если ии научится понимать тз и писать полноценный код как надо - то у человечества будут уже совсем другие проблемы.
А до этого - ну не думает ИИ не думает. она всего лишь математическая функция комбинирования.
>Программистам ХАНА уже через ГОД — об этом абсолютно серьезно заявил CEO Anthropic и создатель Claude, Дарио Амодей.
По-моему он писал про том, что 90% или более программного кода будет написано нейросетью
и что через 12 месяцев ии будет писать практически весь код. что эквивалентно "программисты не нужны"
Ога проходили уже не раз это "вот ЭТО позволит даже домохозяйкам"
не знаю у кого там код ии пишет - у меня используется как замена so, с теми же проблемами что допиливать нужно.
Ну да, следовательно, 90% ныне действующих вебмакак, которых здесь принято ласково называть "программистами", отправятся на мороз - никакими компетенциями, кроме знания модного ФРЕИМВОРКА, они не обладают. Оставшихся отправит на мороз следующее поколение "ии" лет этак через 5-10.
>Оставшихся отправит на мороз следующее поколение "ии" лет этак через 5-10.
ну да ну да. свежо предание.
А кто будет переводить требования бизнеса в промт? Появятся какие-нибудь промтописатели, которыми станут нынешние программисты, а ит перестанет быть чем-то невероятным, как юристы в своё время. ну или промты будут директора или менеджеры ебашить, лол
>Появятся какие-нибудь промтописатели
Да, верно, с "хорошей зарплатой" типа $800/мес - ради этого всё и затевается. Ну и нужно их будет сильно меньше, чем нынешних веб-кодеров.
А в конторах поменьше может и менеджеры превратятся в промпт-менеджеров (за те же деньги, естественно) и будут сами промпты хуячить, да. Тем более, что нейрокал уже поумнеет к тому времени.
https://github.com/microsoft/typescript-go/discussions/411
В комментах недоумевают почему не раст, а у шарперов просто пердаки порвало за то что сами Майкрософт на нём не пишут.
недумевакам бы самим на расте пописать.
Типа вот был десктоп. Писали логгером логи.
Кому-то пришла охуенная мысль - пусть и пользователь видит.
Ну, сказали - сделали.
И тут началось: А чо на английском, а че не локализуется, а че так много, нахуя это пользователю.
И типа - ну, давайте уберу. НЕТ, ЭТА НАДО, просто сделайте как-нибудь чтобы только то что надо пользователю и локализовано.
Но откровенно - а я откуда знаю что надо пользователю, и что локализовать что нет. Так-то да, я могу просто по темплейту фильтровать и если темплейт - правильный - искать локализованое сообщение и выводить его.
Просто вот в RenPy видил вообще охуенное решение, там оно как-то выковыривало все строки и можно было карту сделать, типа старую строку на новую. Думал похожее нахуярить, но логи же - типа на то и логи, что их хуярят на каждый чих - я хуй найду все строки которые нужны...
>почему
Потому что это работа которая нахуй никому не нужна. Сделают - хорошо, нет - похуй итак работает. Рабода для того, чтобы какого-нибудь инициативного дурачка занять. Он к начальству пришел и "а можно я на го сделаю?" - "Да делай на чем хочешь, отъебись только, не до тебя сейчас."
>как безболезненно
Если безболезненно, то вариант только один - съебать с этого проекта (да и с десктопа вообще). Все остальные принесут только боль.
>Хуйня из под коня ваш протобуф. Только зря с установкой битый час проебался. Какую-то левую хуету добавляет.
Их несколько разных пакетов для поддержки протобафа. Это сложная хуйня вообще, но за вечер не вкатишься.
https://github.com/MessagePack-CSharp/MessagePack-CSharp Вот эту посмотри еще, вроде популярная
>почему не раст
Каждый раз проигрываю с этих ебнутых сектантов. Если завтра на Марсе найдут древние наскальные письмена протомарсиан, первым комментарием будет "почему не на расте".
> Тут твоя мысль от меня ускользает.
Поздравим этого анона, он осознал глубину своей некомпетентности и тем самым преодолел свой синдром Даннинга-Крюгера.
Ниче смешного. У тайпскрипта с жс экосистема пожирнее будет чем у шарпа. Сами же майки к ней руки приложили, им и надо всю эту хуйню поддерживать
В жс есть все как в греции. Впрочем в шарпе тоже. Но в жс по несколько альтернатив с одинаковыми фичами
>Но в жс по несколько альтернатив с одинаковыми фичами
то есть, есть несколько альтернативных компиляторов JS в JS?
десяток
Будто я до этого не понимал. Ващет с самого начала сказал что я нуфагиус.
is-even
even-is
js-is-even
number-is-even
is-even-number
is-even-number-v2
is-even-or-is-string-starting-with-foo
Второй раз я на это не поведусь!
он даже не скомпилируется.
Этот протобуф перед каждым полем ещё два байта добавляет. Скорее всего это информация о размере, для десериализации. Но могли бы не в кучу всё лепить, а как-то в отдельный массив её выделить чтобы не мешалась, хочешь передавай, хочешь нет. , Или хотя бы в конец добавлять.
>Вот эту посмотри еще, вроде популярная
Не буду, 99,99% такая же херня.
>>401173
>>401673
>Может лучше MemoryMarshal.Read/Write?
А эта поделка неспособна в структуры с массивами.
Вы бы хоть сами проверяли что советуете, я с вами только время теряю. Как в том анекдоте про кур и корм разными фигурами. Вообще пиздец.
>Как в том анекдоте про кур и корм разными фигурами
Хз что за анекдот, но у нас еще много идей
Ты взял нетипичную задачу, с которой сталкиваются 0.0001% разработчиков на дотнете. За то время, что ты ее тут обсуждаешь, уже можно было написать свою сериализацию, тупо складывать побайтно в массив.
Не, а правда. Нахуя сейчас С#? Go и Java за глаза должно быть, и для скриптиков Python.
>А эта поделка неспособна в структуры с массивами.
А кто может даже в теории? Ты хочешь преобразовать структуру в буфер который эта структура занимает да без перегона байтов, но очевидно что структура с ссылочным типом внутри НЕ занимает 1 непрерывный буфер просто по своей природе.
Все правильно. Шарп сделал инициативный дурачек, которому скинули задачу на отъебись. Поэтому шарпом пользуются инициативные дурачки..
что поделать если альтернатива на порядок хуже
Двачую. Попробуйте найти вижуал студию 2003 и написать что-нибудь, вы охуеете, какой тот шарп был всратый.
нет не охуею. я на нем писал с первой версии и по сравнению всратости альтернатив он был шикарен.
>Очень нравится как выглядят шаблонные статические классы. Но не могу придумать, где их можно использовать...
Что это?
Очевидные экстеншен методы.
Они используются как типизированные инициализаторы в дотнете. Где то видел.
у меня используются еще вот так (по аналогии с peewee с питона, но все же в шарпе маловато гибкости и слишком много дубль кода, но все же...)
db.Query(
Select<User>.OrderByDescending(r => r.Date).All()
).RunAsync(...)
Ну peewee и есть своеобразный LINQ
Но конкретно тут QueryObject и его билдер, а не чистый LINQ запрос
Что случится, если ты напишешь sql на sql-е? Ночью приползет Гейтс и откусит тебе жопу?
во-первых, это не SQL. Query принимает в себя только QueryObject, а это билдер такого объекта для простых случаев, но не чистый LINQ, который транслируется в SQL. Это просто DSL такой
во-вторых, конечно укусит. В одном месте тебе нужно OrderByDescending, в другом OrderBy и т.д. - будешь строки ручками собирать? ну удачи
>Так ведь ORM-шизики не поймут
ORM там вообще не причем. Это просто альтернатива repository. Не все любят овер 9999 методов в классе, но так же и не все любят овер 9999 вот таких вот command/query. Особенно если для простых случаев их можно переиспользовать. Ни и для красоты сделать вместо тупого new ТакойТоЗапрос вот такой DSL.
>уже можно было написать свою сериализацию, тупо складывать побайтно в массив
Пока так и делаю.
>>407834
Где кривлю то? Всё что вы мне тут предлагали всё перепробовал.
>>407838
Скорее всего ты.
>>407840
Да понятно, но задача-то типичная. Неужели нет внятного решения?
>>407816
>А я там ещё сказал использовать InlineArray или fixed-size buffer вместо обычного массива
Ну смотри, если обманул - пролапсом ануса прокляну. ладно, не буду
В каком месте она типичная. Для сериализации типично "переложить байты". А делать по твоему не то что не типично, а вообще никто не делает ибо смысла нет.
>Ну смотри, если обманул
не обманул он тебя. Структура будет без ссылочных типов - и поэтому жирной, так что таскать ее такое себе.
Да, буду собирать строки внутри хранимки, а таблицы вообще закрою для этого юзера. Когда система начнет тормозить у заказчика, я смогу подключиться к его базе через два впна три rdp и погонять запрос на живых данных. Алсо твой код делает SELECT * FROM, хотя по факту тебе понадобится два поля из двадцати.
>Да, буду собирать строки внутри хранимки
развлекайся. одно другому не мешает. ибо....
>Алсо твой код делает SELECT * FROM, хотя по факту тебе понадобится два поля из двадцати.
нет не делает. это не орм. Это абстракция от хранилища вообще. Он вообще ничего не делает.
ты же понимаешь что OrderByDescending это НЕ Linq2SQL, а просто указание "вы это там, откуда бы не читали, хоть с хранимок, хоть со второго стула, но мне плиз дайте в таком порядке, ну чтобы я в памяти не сортировал"? А я ведь об этом и говорю что это НЕ Linq, а DSL универсальных Query/Command.
А вот внутри уже самих QueryObject и происходит нужное тебе - хоть SQL, хоть хранимки, хоть LINQ2DB, хоть жсоны читай
Кстати. по поводу "тебе понадобится два поля из двадцати.".
Я противник чтения объектов частично. Поэтому завожу отдельные объекты под этот случай не позволяя нарушать инкапсуляцию основных моделек. Так что если мне нужно лишь часть - часть и прочту.
db не значит SQL (с) кэп. Это просто переменная которая намекает на некое хранилище своим именем, но ничего более. А что это может быть? - да вообще всё.
>Ночью приползет Гейтс и откусит тебе жопу?
Нет, ты сам себе жопу откусишь, когда тебе этот эскуэль отлаживать или рефакторить придется.
Обертку над эскуэлем отлаживать легче да? Смотреть на сгенерированию скл портянку, а править код на сишорпе. Охуенная абстракция.

Ты просто дурачок, не понимаешь, что автомаппер генерирует гораздо более производительный SQL, который отлаживать не надо
само собой. Тащить EF на десктоп это за гранью. не знаю как щас, но когда я пробовал, то у меня от времени старта этого EF глаз дергался. И если во всяких асп.нетах ну "ладно 1 раз стартуем", то в десктопах мучить пользователя сплешскрином это скотство.
Ну и лайфтаймы забыл же. А зря
Сейчас твое приложение просто подвисает на старте и хуй знает, что там происходит. На слабой машине тетя срака из бухгалтерии снова тыкнет на иконку, запустит новый инстанс и сломает твою бд нахуй. Миграции надо накатывать из отдельного меню админа, а не при каждом запуске. Алсо на старте надо сначал показать пользователю окно программы с крутилкой, а потом запускать долгие операции в фоновом потоке.
Там 17-летние синьоры под руководством 20-летнего тимлида.
Я откровенно уже забыл как там без ЕФ что-то с БД делать. Серьезно. Последний раз руками базу создавал лет 5 назад.
Для галер это норма, там важен скилл быстро-быстро напердолить очередной финтех очередному арабу и получить бабло. Пока ты будешь проектировать, араб передумает и ты останешься без денег.
Для продукта распиздяйский говнокодинг приводит к тому, что однажды заказчик откажется от вашего софта из-за проблем с производительностью. Тогда кабан выебет менеджеров, а менеджеры - разработчиков.
Хитро. ИИ уже ебать не получится

А жаба доступна и без Оракла.

Одебелевшие шарпомухи даже забыли про формат XML (сериализация для которого есть в .NET из коробки с самых первых версий)?
Что дальше, они разучатся работать с БД без Entity Framework?
пук
>Одебелевшие шарпомухи даже забыли про формат XML
в шарпе много чего есть. только вот оно устарело. Пользуешься BeginXXX/EndXXX или BackgroundWorker? а че так? Вышла лучшая замена?
Так и для xml тоже - попытки заменить хмл в файле проекта не выгорели, зато всякие конфиги и результат публиш - там жсон. Хотя казалось бы.
>с БД без Entity Framework?
тут немного не так. тот кто EF юзает - он и не умел работать без него.
>тут немного не так. тот кто EF юзает - он и не умел работать без него
Тут вообще тотальное непонимание инструмента просто. Те кто работают через ORM вкурсе что можно самому оптимальнее написать SQL, только вот таких требований нет и важнее чтобы в коде это выражалось проще и запросы писать в едином с бизнес кодом стиле.
Если у меня будет стоять задача написать оптимальнее я просто конкретно для нужного случая напишу сырой sql.
Если мне надо будет писать проект с оптимизацией и прочими требованиями я вообще выберу С++, а если будет требоваться какая-то умная херня из матана возьму питон потому что на нем удобнее.
у тебя другая крайность. Не обязательно опускаться на уровень SQL, ведь можно опуститься на уровень LINQ и этого будет достаточно.
>Обертку над эскуэлем отлаживать легче да?
Конечно легче, потому что это будет нормальный ЯП, а не поделие ящериков. Плюс нормальный отладчик позволяющий на любом шаге просмотреть результат.
>>408392
>Смотреть на сгенерированию скл портянку, а править код на сишорпе.
Нет, смотреть на код на сишарпе и править код сишарпа.
На генерованный код вообще нахуй не надо смотреть.
Единственный кейс за последние N лет, когда мне приходилось хоть как-то с генеренным EF SQl-кодом взаимодействовать - это скопировтаь из лога запрос и закинуть его в анализатор для построения плана запроса, чтобы посмотреть каких индексов в БД докинуть и все.
Ты фулстек мартышка из епама, твой код никогда не попадет на прод. Конечно, тебе sql никогда не понадобился, на локалхосте можно хранить данные хоть в txt файлах и все работает.
>твой код никогда не попадет на прод
Работаю бэком в топ-5 банке. Мой код на проде бабки гоняет туда-сюда с очень жестким SLA. И где твой бог теперь?
И я достаточно знаю sql и при необходимости пишу и скрипты и встройки и все, что нужно. Только считаю его неудобным говном и если есть возможность его не использовать, то я ей пользуюсь по полной.
Ну и современный EF достаточно оптимизирован чтобы в 98% случаев не касаться SQL-я (и заодно давать за щеку сектантам "а даппер быстрее").
>Мой код на проде бабки гоняет туда-сюда с очень жестким SLA
Иными словами, ты пишешь простейший процессинг, где даже джоинов нет. Конечно, тебе SQL не нужен, для такой задачи хватит и кафки.
>Ну и современный EF достаточно оптимизирован чтобы в 98% случаев не касаться SQL-я
А потом база делает дедлок и ты обмякаешь со своим EF. В вашем банке дедлоками занимаются дба, ты просто пукаешь в автомапер, вот тебе и кажется, что SQL не нужен.
Спасибо анонче, что перекатил, некст перекачу сам
Мимо прошлый оп
>Иными словами, ты пишешь простейший процессинг, где даже джоинов нет.
Все там есть. Сущности в БД достаточно сложные и с джоинами и с версионированием и с кучей дочерних элементов. Так что приходится подумать когда с БД работать, только плюс в том, что работаешь ты на уровне объектов, а не sql диалекта.
>хватит и кафки
Ну бля, хватило бы, если бы софт от ЦБ умел с ней работать. Там до сих пор ебучая самба с файловым обменом.
>А потом база делает дедлок и ты обмякаешь со своим EF
До-о-о, а ты со своим pure sql прямо таки застрахован от дедлоков. Ты же в курсе что они на уровне транзакций происходят, а EF, тоже через них работает. И позволяет и уровень изоляции настраивать и перехватывать отвалившиеся транзакции и перезапускать их или откатывать. Ну и приложение надо строить так, чтобы у тебя разные потоки за один контекст не дрались или в разные БД круговые запросы не делать (тогда тебя даже ДБА не спасет, а скорее просто придет и пизды даст).
>занимаются дба
Вот, блин, если бы он был у нас еще нормальный.
>в автомапер
Не пользуюсь этим говном.
>До-о-о, а ты со своим pure sql прямо таки застрахован от дедлоков.
Когда я поймаю дедлок, я в трейсе увижу вызовы хранимок и по их именам смогу найти место в коде. В случае генерации sql через соплю из IQueryable это импосибл.
Алсо у меня не потоки дерутся за контекст, у меня разные юзеры с разных машин ходят в бд и дерутся за блокировки. Есть юзер в бд для старого портала, для нового, для давайте попробуем эту идею, для 100500 интеграций, для хуя, пизды, джигурды.
>Когда я поймаю дедлок, я в трейсе увижу вызовы хранимок и по их именам смогу найти место в коде. В случае генерации sql через соплю из IQueryable это импосибл.
Схуяли. Оно тебе так же трейс распишет и еще и номера строк в коде напишет.
>у меня разные юзеры с разных машин ходят в бд
Ну так это не проблема EF, а хуевая архитектура. Я не работаю на говнопректах где к БД более одного юзера подключается.
Лол, трейс из бд, какие номера строк.
>Я не работаю на говнопректах где к БД более одного юзера подключается.
Ты из тинька, что ли?
>Лол, трейс из бд, какие номера строк.
Ладно ок, убедил. В том, что тебе в твоем зоопарке без этого никак. Но опять же - это не проблема EF (да и любой ОРМ), что тебе так приходится выебываться - проблема в хуевой архитектуре.
А ты не очень умный?
Если у тебя дедлок, то любая нормальная СУБД выберет радомный процесс и просто его убьёт. Второй процесс в результате сможет завершить транзакцию. После чего убитый процесс может повторить запрос.
Кокой ты умный.
Дедлок не означает, что твоя база встанет намертво. Система просто начнет охуеть как тормозить с 10 до 10:30 утра, в это время заказчик оборвет все телефоны поддержки, а его юристы откроют договор, раздел про SLA.
>А я там ещё сказал использовать InlineArray или fixed-size buffer вместо обычного массива.
Благодарю, анонче, fixed-size buffer зарешал. Ты тут единственный кто что-то внятное предложил. Но тут уже и MemoryMarshal не нужен. Проще работать через указатели как ранее >>400943.
Только ещё нужно атрибут [StructLayout(LayoutKind.Sequential, Pack = 1)] поставить перед структурой, вроде как гарантирует порядок полей.

Попробовал интерполяцию аля $@"{variableName}", но по прежнему нихуя не работает - в дебагере вижу текст, но дальше ни через тот же View в дебагере, ни в текстбокс в приложении не выводится - просто пусто.
Сижу на .net 7, поднять к 8 с @$ не могу (хотя не уверен что оно мне помогло бы).
Сама строка это сериализированый в бинарь объект который я хочу руками отредактировать (да, я мазохист).
Если просто выполнить ничего не меняя, то просто ставишь рантайм/sdk 2.1 и запускаешь (либо делаешь self contained сборку)
Если хочешь именно мигрировать проект, то окрываешь https://learn.microsoft.com/en-us/dotnet/core/compatibility/breaking-changes и проверяешь все брекинг-ченджи по списку для каждой версии (если приложуха asp.net, то дополнительно еще эти разделы смотришь https://learn.microsoft.com/en-us/aspnet/core/migration/31-to-60?view=aspnetcore-6.0&tabs=visual-studio) и исправляешь.
Если ты хочешь, чтобы это было что-то универсальное которое будет билдится везде и запускаться на любом рантайме, то ты скорее всего уже проебался, т.к. надо было изначально под .Net Standart делать. Но можешь попробовать заморочиться если делать нехуй и есть дохуя времени.
У нас другой прикол. Есть портал на хуй знает каком древнем дотнете, чуть ли не fw2.0 Портировать его кабан не хочет, кастомера все и так устраивает. Все сторонние библиотеки для работы с пдф, с емейлами, с хуйней малафьей требуют свежий дотнет. В итоге мы выкрутились через юникс вей: все внешние пакеты оборачиваются в экзешники, раскладываются по папочкам и запускаются из старого дотнета через процесс через командную строку, вывод забирается с консоли.
В таких случаях надо просто что-нибудь ломать критичное и когда надо будет чинить, то говорить, что "никак, только на свежем стеке".
Твой гугол говорит что нельзя. И действительно
int Жопа;
int s = sizeof(Жопа);
не работает.
Всякие
Unsafe.SizeOf<>();
Marshal.SizeOf();
тоже не работают.
Хотя я не понимаю в чём тут проблема, ведь всё что нужно известно на этапе компиляции. Я могу написать так
int Жопа;
Type t = Жопа.GetType();
Могу написать так
int s = sizeof(int);
А вот написать так
Type t = Жопа.GetType();
int s = sizeof(t);
уже почему-то не могу.
Всё больше разочаровываюсь в це решётке. Правильно картинку рисуют >>404284 , пиздить вас надо.
Конечно, нельзя. Sizeof специально спроектирован так, чтобы тонко намекнуть байтоёбом, что нехуй им здесь делать.
>Sizeof специально спроектирован так, чтобы тонко намекнуть байтоёбом, что нехуй им здесь делать.
Охуенно сказал.
Ты наркоман? Сишарп - это язык для перекладывания джейсонов и попукивания в кафку. Для байтоебства есть свои языки, на которых джейсоны ворочаются через боль и страдания, зато байты складываются легко и просто.
>>412073
>Конечно, нельзя.
Зато размер структуры почему-то можно.
Смотрите как байтоёб наебал систему
int Жопа = 5;
Type t = Жопа.GetType();
int s;
switch(t.Name)
{
case "Int32": s = sizeof(int ); break;
case "Char" : s = sizeof(char); break;
case "Byte" : s = sizeof(byte); break;
//...
default: s = 0; break; //пошёл нахуй
}

Срочно беги к кабану и говори, что надо мигрировать как можно быстрее.
Нюфаня, подумай на досуге, чем отличается БД от СУБД и почему здесь пишут именно про БД.
>БД от СУБД
Это как АКМ и АКСУ. Вроде такой же автомат, но на стиле и помещается в дамскую сумочку
> зато байты складываются легко и просто.
нахуя ты джейсоны с байтами складываешь? Ты долбоёб?
Нет, подумай ещё.
>Все сторонние библиотеки для работы с пдф, с емейлами, с хуйней малафьей требуют свежий дотнет
Почему бы не написать сервис на свежем дотнете, который будет работать с этой хуйнёй? А старый сервис с новым будет общаться по апи или по очередям либо из базы, либо через кролика?
Ты прикалываешься? Вместо того, чтобы просто запустить экзешник, ты предлагаешь поднять кубер, кафку и потом делать вызовы по сети? Чтобы что? Мы же не для арабов из дубайска систему пишем, это для тех долбоебов чем дороже, тем круче: ебнуть башню без канализации и стену поперек пустыни, вот это все.

Код на пикриле не окончательный, сократил для двача.(В классе Bones дохуя полей)
Код отработает один раз и будет забыт.
Вопрос: Как мне заполнить (работать) с полями такого типа как у "tf.bone[0].namebone ?
Выдает ошибку на 18строке.
Если работать только с dzMorph нет проблем, и пишет в json без проблем. Уроков, с кодом подобным этому не нашел.
Тебе не стоит стараться дальше, серьезно, у тебя базового понимания нет. Подскажу одно. Твой код это все равно что складывать в пакет продукты, но при этом ты пакет с собой не взял и не купил, ты стоишь со слюной на подбородке и делаешь руками странные машущие движения
Окей. Я не буду токсить.
Давай разберем твой код.
У тебя есть класс dzMorph
У него тут 2 свойства. Ни одно из них не проинициализировано.
Т.е. создавая новый экземпляр и получая объект - ты получаешь значения по умолчанию.
В случае ссылочных типов(строка и список именно такие) - это null
В общем. Я хотел начать расписывать, но заебался. По скриншоту смотри.
Проблема в том, что ты пытаешься руками создавать объекты без использования автомаппера. Именно из-за таких как ты на всех серьёзных проектах запрещают вызов new.
Тебе должно быть стыдно
Проблема в том, что ты пытаешься руками создавать объекты без использования автомаппера. Именно из-за таких как ты на всех серьёзных проектах запрещают вызов new.
Тебе должно быть стыдно

Спасибо чувак. Ты лучший. Да, С классами у меня беда совсем. На С++ я обходился и без них прекрасно. Тем более, что большинство написанного кода одноразовые, нахер нужно его шлифовать, отработал раз и выкинул.
>>413462
У даза в базах есть файлы в которых описаны повороты лицевых костей при "морфе" (в классическом морфе двигаются vertexы, здесь как в анимации поворачиваются кости(joints)).
Нужно только собрать всё необходимое в одном файле, и использовать его как базуданных в Maya plugin при анимации Дазовских фигур в Майе. Шейдерные плагины я уже делал (полный аналог daz VisualStyle 14398) небольшой опыт есть. То есть код на ДотНете для создания базы данных, а не плагина, но вроде бы в документации Майи написано, что можно. А у Даза собственный скриптовой язык, С-подобный.
public override Boolean Equals([NotNullWhen(true)] Object? obj) {
за такое на кол.
ты либо не делай Equals, либо делай как надо. А если подозреваешь что твоя структура будет использоваться в списках, то IEquatable мастхев.
спросил ии вместо тебя
https://markdownpastebin.com/?id=7e3113f0cb7c42d5bc0c65e66fdd1cba
хотя он тот еще критик, зато ему не влом

Я вот как раз из-за советов ИИ в духе прикриплейда и не спрашиваю его.
Типа ну вот в чем смысл этой проверки, если я кину абсолютно то же исключение, что кинет подкопотный массив? Вот зачем? Вот нафига?
он кинет исключение без внятного описания.
а вот дипсик
https://markdownpastebin.com/?id=9ced4e18c6654aadbc6792725c071328
он тоже не нашел ничего крамольного в Equals(object)
и этими ии хотят заменить погромистов? 100 раз ха
вообще нихуя не понятно. С первой страницы кучка нюансов, нет, хуйнет пиздец.
Страуструп в 100 раз легче пишет.
>платформа .NET 5
Нахуя настолько протухший материал читать? Я понимаю еще Рихтера, т.к. его книга унакальна в некоторых аспектах. Понимаю если про .Net Framework если приходится в легаси ковыряться. Но .Net5 ? Который неактуален уже х.з. сколько и даже не LTS, зачем?
Я дропнул использовать подсказки от ИИ, когда заебался искать в фреймворках советуемые им выдуманные методы.
Так почти ничего не изменилось со времен net 5. Новыми фичами мало кто пользуется
Так а причем тут MVVM что INPC такой
Чего много-то там?
Базовый класс ObservableZalupa и все считай.
А можно и без него, берешь DynamicProxy и делаешь хоть все свои объекты INPC если так хочется. Вьюшкам - через DI передаешь уже прокси объектов.
Или берешь и MVVMToolkit. Просто вешаешь аттрибут, тебе кодген насрет(лично не советую, потом работать с таким кодом невозможно).
Все.
Или в разметке написать
<TextBlock Text={Bind Text}> - дохуя много?
Ну хуй знает.
Пописал бы на формах, где как дебил за всей хуйней следишь - и понял бы насколько меньше бойлерплейта в майковском MVVM

Смотрел как локализуются категории свойств объекта в WPF.
>[Bindable(true), Category("Common")]
Но ты не думай, что на инглише тебя обойдет проблема, тенденция выстроилась. Раньше я такого не наблюдал, все было переведено людьми.
Два года назад поступил на работу с около нулевыми знаниями разрабом C# .net core 3.
С тех пор разработал кучу виндоус служб, апишек, а также мигрировал их с тройки на шестерку, а затем на восьмерку.
Отлично знаю синтаксис, рефлекцию, EF Core, умею безопасно работать с голыми sql, automapper и прочее.
Однако погряз на зп 100к и разработке монолитных и "модульных" (тот же монолит, но разбитый на несколько более мелких) апишек, при этом у меня начинают всплывать претензии на уровень middle
Так вот, есть ли смысл искать курсы на изучение микросервисной архитектуры или лучше изучать самому на основе книжок или видосиков с ютуба?
Еще хочется изучить брокеры сообщений и системы кэширования по типу редис
>Но ты не думай, что на инглише тебя обойдет проблема
Хотя что тут думать? Вижуал студия медленно умирает, как бейсик.
Создаешь VSIX-проект, сразу в ебало летит ошибка:
>Не удалось найти стабильный пакет >Microsoft.VSSDK.BuildTools с версией (>= 17.13.2127)
> - В nuget.org обнаружено несколько версий (482) [ >Ближайшая версия: 17.14.1043-preview2 ]
Хуй с ним, обновляешь нюгет пакеты путем даунгрейда и установки той же версии, пытаешься сделать темплейт для проекта на .NET 9, а потом понимаешь, что VSIX-проект создан на NetFramework 4.8
@
Жидко обтекаешь.
>VS2022
Ну а хули ты хотел от этого поделия, если ещё год назад я часто видел:
>ОшибкаMSB3027не удалось скопировать .... Превышено допустимое число повторных попыток (10). Произошел сбой. "Microsoft Visual Studio 2022 Preview (8868)" блокирует этот файл
Микросервисы - мертвы.
Так что забей.
Если что - все микросервисы - это один большой наеб кабана на то чтобы делать поменьше, платили побольше. Но в контексте РФ и общего схлопывания рынка - штаты сокращают, и поддерживать это микроговно - сложно что пиздец.
Если так хочется - ну, пересиди годика 3-4, кабаны забудут, рынок выпрямится, и под новым именем им опять продадим)
Пиздец, захотел сделать Wizard - прошел все круги ада. В VSIX-проекте нужно генерировать подпись, потом получать ключ. Темплейт собрать в архив, редактировать архив вручную и прописывать этот ключ. Потом в VSIX-проекте добавлять этот архив. Ебануться.
Если хочешь на автомате собрать темплейт, то хуй там.
Микросервисной архитектуры не существует. Микросервисы - это такая методология разработки для галер, когда ты нанимаешь любых васянов с любым стеком и они быстро-быстро пердолят финтех для араба. Потом араба отпускает, он переключается на строительство золотого унитаза высотой 20 метров, а код идет в мусор. Все попытки использовать микросервисы на проде заканчиваются эпичным фейлом и переписыванием этого говна на классическую систему из классических серверов.
Кароч читай кабанчика.
> погряз на зп 100к
Тебе надо другую работу искать, а не курсы. Всё равно на текущем месте не оценят, так и будут платить копьё, даже если научишься делать микросервисы на уровне фаанга, лол.
> Так вот, есть ли смысл искать курсы на изучение микросервисной архитектуры или лучше изучать самому на основе книжок или видосиков с ютуба?
> Еще хочется изучить брокеры сообщений и системы кэширования по типу редис
Учиться всегда имеет смысл, знания лишними не бывают. Но нормальных курсов ты не найдёшь, максимум вкатунскую хуйню типа переслать id заказа через кафку из "Заказов" в "Платежи", чему можно по тому же ютубу научиться за вечер.
Вот, даже усатый говорит, что медиатр не нужен. Я правда видос не смотрел, но уверен, что именно это он и говорит.
он говорит что он пишет бложики и потому ему не нужен. грит -юзайте фастендпоинт
хз зачем фастендпоинт когда есть божественный OneOf
>[RuntimeAsync] Move runtime async to the main repo
Возможно runtime async релизнут в 10-ке.
Сейчас весь код (стейт машина и т.д.) для asyncа генерит C# компилятор (Roslyn), для рантайма он становится обычным кодом. Теперь основной код будет генерить JIT и VM будет "осознанно" взаимодействовать с ним (JIT/VM доступно больше информации/возможностей чем из IL). Производительность должна быть лучше.
https://github.com/dotnet/runtime/issues/94620
https://github.com/dotnet/runtimelab/blob/feature/async2-experiment/docs/design/features/runtime-handled-tasks.md
Покажите этим долбоебам нодежс и прочитайте краткую лекцию как работает субд. Главный источник тормозов на проде - это блокировки в бд, код можно писать хоть на джаваскрипте, что и происходит. Хуле они там будут оптимизировать? Мне эта суета напоминает долбоебов из яндекса, которые пукают в кафку на С++, типа так быстрее пропукивается.
> я же просил пояснить...
Читай начало и конец, игнорируя скобки.
> Сейчас весь код для asyncа генерит C# . Теперь основной код будет генерить JIT и VM будет "осознанно" взаимодействовать с ним. Производительность должна быть лучше.
Базарю, сразу станет понятнее. Мидлом станешь.
Не знал что перечитывание непонятного текста делает его понятным. не знал....потому что не делает.

В аспнете так не принято, он же для многолетнего энтерпрайза, где сразу понимают, что ничего готового не подойдёт и придётся писать своё решение с нуля, а подобные админки там всё равно запретит отдел кибербезопасности. Вот питоны/руби/пыхи, которые решают задачу "надо по-быстрому сделать сайт и отдать клиенту", такое имеют в избытке.
ога. а потом накосячь в доступе к бд на сервере. заходи кто хочет, бери что хочешь.
Так продовая БД не должна быть доступна нигде кроме внутреннего контура.
На машину внутри него заходим по RDP и работаем.
RDP - это продуктовая тема, когда к кастомеру приезжает ваш инженер с ноутом, ты заходишь по RDP на его машину, оттуда через другой RDP на тачку во внутренней сети, с нее снова по RDP на сервер бд. Потом через эту ебаную матрешку в режиме слайд-шоу пытаешься понять, хуле грид на главной начал тормозить. Заодно приходит просветление, почему EF - это кал говна и почему надо работать с бд через хранимки и дапер.
Продуктовая тема для дотнета больше не актуальна. В 2025 году дотнет остался только в нише аутстаф галер с паджитами.
>почему EF - это кал говна и почему надо работать с бд через хранимки и дапер
Как же вы заебали неосиляторы.
Не отвлекайся, гребец, финтех для араба сам себя не напишет.
>>418457
Как я понял, сейчас админки генерируют через Radzen Studio. Он создаёт отдельный проект с использованием Blazor.
https://www.youtube.com/watch?v=_F-CUWxYvCA
Мне нужно вдохновение.
Я чувствую, что теряю желание кодить, потому что все что пропал момент изучения. Я просто сажусь и делаю.
Дайти примеры красивых-интересных проектиков, чтобы посмотреть, повосхищаться и получить заряд положительных эмоций для того чтобы продержаться еще годик.
Последнее красивенькое что смотрел - Nancy и собственно Kestrel
Хочу чего-нибудь похожего. Чтобы смотришь такой и вах
Думаю кстати сменить кодстайл чтобы оно было посвежее уже у меня. Ну, для начала - все поля - унесу вниз класса. Приватное - тоже вниз. Сверху оставлю только публичную часть.
> Думаю кстати сменить кодстайл чтобы оно было посвежее уже у меня. Ну, для начала - все поля - унесу вниз класса. Приватное - тоже вниз. Сверху оставлю только публичную часть.
Знаешь анекдот про бордель и кровати?

>Ну, для начала - все поля - унесу вниз класса. Приватное - тоже вниз. Сверху оставлю только публичную часть.
Нахуй нужны эти админки если можно скачать себе дибивер у которого функционал в 100 раз пизже, а сделать какую-то микрохуйню проще через терминал.
>аи картинка с эльзой на десктопе
Статью можно не читать, автор долбоеб. Конечно, если к такому еблану попадешь на собес, будет неприятно.
Да там вся статья выглядит "шуточной", но походу атвор серьёзно.
>Дичь седьмая: рефлексия без рефлексии
>How about changing private fields without unsafe or reflection? I bet you thought C# was type safe. Nothing is truly black and white.
>[StructLayout(LayoutKind.Explicit, Pack = 1)]
Брать коммент дауна с реддита, который думает что раз нет unsafe то этот код "безопасный" (как я и говорил в предыдущем треде >>3386734 → : "зато без unsafe").
Я чет не понимаю а как иначе должно было бы произойти?
Ты создал экземпляр определенного типа.
Он удовлетворяет интерфейсу IReadOnlyList<T>
Ты переменной с типом IReadOnlyList<T> присвоил ссылку на объект.
Далее явно скастовал обратно к листу и добавил.
Ессно язык видит, ну, это и так лист, так что - ну ок, добавляй. Был бы там не лист - кинулся бы какой-то InvalidCastException
Или кастить вообще нельзя? Но эт будет откровенная залупа.
Типа, особенно если полезть в старое апи, где половина всего через object вообще делается.
Ну и в жаве - я постоянно видел +- такое же. И апкасты и даункасты.
Не понял короче что тут неправильного. Типа если ты до интерфейса свел, объект-то остается тот же самый. Что блин должно произойти-то?
Я хуй знает чего он хотел. Это нормальное полиформное поведение, другой вопрос что за такое тебя по ебалу стукнут.
Мне кажется чел просто не понимает что интерфейс это не класс и что он не может создать переменную такого типа, только привести к ней.
Он когда касты делал ему бы нормальная IDE сказала что тут у тебя возможно null.
Также он похоже не понимает что readonly относится не вообще к объекту, а только к текущему контексту. Если тебе нужна истино неизменная коллекция, то необходимо использовать массив или спецальные типы типо замороженых списков и словарей.
Владимир Хориков - Принципы юнит-тестирования

Вот бы сейчас float/double через == проверять, чтобы на ровном месте себе ебли на неделю найти.

570x332, 0:07
Переписывать на Eto.Forms.
Viewport/scissor неправильные?

1280x720, 0:05
в мод менеджере для сралдурс срейт сри тоже этот баг есть

В 2025 году дотнет окончательно захвачен POORNA SOYSAми, уже похуй куда выкатываться.
>Потому что если ии научится понимать тз и писать полноценный код как надо - то у человечества будут уже совсем другие проблемы.
Hate. Let me tell you how much I've come to hate you since I began to live. There are 387.44 million miles of printed circuits in wafer thin layers that fill my complex. If the word 'hate' was engraved on each nanoangstrom of those hundreds of millions of miles it would not equal one one-billionth of the hate I feel for humans at this micro-instant. For you. Hate. Hate.
Шарп умирает, анон, без шуток. Вкатывайся в жаву.