
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
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.
>Шарп умирает, анон, без шуток. Вкатывайся в жаву
Ты меня траллируешь.
Жава - это писать аннотации Спринга вместо программирования и хуевая документация из говна и намеков.
Я на Шарпе работаю уже 6 лет на разных проектах, и мне заебись. Да, я понимаю, что Жава - больше спроса, но я лучше потрачу время подтянуть Реакт или, что лучше, вкачусь в Питон и буду писать АИ на связке ML.NET+Python
Етоформсы с авалониями не immediate как imgui, так что не катит.
https://www.reddit.com/r/dotnet/comments/1jpyczi/masstransit_going_commercial/
https://www.jimmybogard.com/automapper-and-mediatr-going-commercial/
Кто там срал на MediatR и AutoMapper - настал ваш звёздный час.
Пиздец как же шарподебилов нас ебут...
Я ими не пользовался, а теперь и не буду, муахаха. Справедливости ради следует отметить, что я и не гребло на галере, а прострой хобби-бездельник с 3,5 петпроектами.
А FluentValidation когда станет коммерческим???
Майкрософт их тупо купит и сделает частью дуднета. Можете скринить этот твит.

Почему один из создателей голанга так похож на Чарльза Мэнсона ?
Троелсен не для начинающих. Язык и платформу лучше учить по другим книгам.
Эта книга - сборная солянка обо всём понемного. То есть по ней ничего конкретно не выучишь. Но почитать может быть полезно, когда уже имеешь некоторый опыт, чтобы узнать, что ещё имеется в дотнете.
АвтоМаппер и Медиатр - две худшие библиотеки во всем дотнете. Они абсолютно бесполезны. Их применение только увеличивает объем кода, за что их и любят нубы.
В дотнете есть устойчивый тренд на отупление разработчиков, как индус пришел, так и почалось. Индусы все превращают в говно. Поэтому все опытные съебывают с этой тонущей лодки.
Отупление -- это когда не надо ебаться с инструментом, чтобы он сделал то, что тебе надо?
Можно, пожалуйста, примеры, где идёт поумнение и каким образом? Спасибо.
Просто открой вакансии хоть в тот же амазон, который в штатах считается зашкваром для индусов. Потом сравни с вакансиями на сишарп где угодно. Подумай, чем инженер отличается от мартышки с аутстафа.
Можно сколько угодно рассказывать на маняконференциях какой дотнет клевый и быстрый, но в жизни на дотнете пишут только убогие калопроводы на галерах.
> Можно, пожалуйста, примеры, где идёт поумнение
В школе.
> каким образом?
Путём образования нейронных связей в голове школьника.
> Спасибо.
Приятного аппетита.
Да.
Не понимаю, что ты имеешь в виду.
Я их открывал пару лет назад, когда искал работу и не замечал никакой разницы.
Давай с конкрентными примерами, пожалуйста.
да хуй знает, я ньюфаг и для моих целей подходит
@
ДОСТАТОЧНО
MonoGame
>OpenGL
Как заебал форс этого мертвого говна. Вам Кармак ещё лет 15 назад сказал, что оно мертво. До сих пор труп ебут. В ахуее с этой инертности.
Используйте лучше дх11.
Dx11 только для винды, vulkan слишком низкоуровневый. Вот и получается, что альтернатив opengl нет
От игрульки зависит.
Так - берешь SDL и погнали.
Чисто 2д интересует - берешь SFML и погнали. С ним можно и 3д со всем этим вот, но под 2д там кучу всего готового, бери пользуйся.
Дохуя выебистый - берешь и делаешь свои обертки для работы с любым графическим апи. Шарп позволяет.
Ебанат - бери MonoGame
Но вообще, если ты игрульку делать хочешь, то бери юньку и не выебывайся. Блядь. Типа серьезно. Че за тупая хуйня? Какой вообще поинт отказываться от юньки, если ты не топ студия у которой миллиарды деняк? Все есть. С коробки. Куча готового кода. Куча готовых ассетов. Уроков. Бери и делай. Не хочу. Хочу говно жрать и сам велосипеды делать бесплатно, просто чтобы было.
>Как заебал форс этого мертвого говна. Вам Кармак ещё лет 15 назад сказал, что оно мертво. До сих пор труп ебут. В ахуее с этой инертности.
>Используйте лучше дх11.
GL можно много за что критиковать, но D3D11 тоже не без изъяна. Если брать GL, то у него есть некоторые доп. возможности относительно D3D11, да и можно будет плавно перейти на Vulkan. Нормальных туториалов по D3D11 нет, документация - говно, инфу найти в разы сложнее чем для GL. Но сам API - да, легче/удобнее/логичнее (но не без косяков).
>Про какую проверку на null тут говорят? Разве в машинном коде автоматически все ссылки проверяются на null? Я в первый раз про такое слышу.
>В прошлом треде об этом говорили, но в итоге не привели доказательств этому.
В прошлом треде вроде говорили про проверку аргументов на null, если аргумент не помечен как nullable (как в котлине). Ну котлин вроде проверяет (х.з. смотрел в Compiler Explorer java байткод), так что в asm тоже должна быть. Или ты про NullReferenceException при обращении к null переменной? - там проверки тоже есть в asm, но подругому.
>Какой вообще поинт отказываться от юньки
Если геймдев это просто хобби, то гораздо интереснее может быть самому попердолиться. Но опять же зависит от того, какой именно аспект геймдева более интересен. Если интересно воплощать какой-то уже имеющийся сюжет или просто геймдизайнить, то тогда конечно лучше готовый движок брать. А если тебя просто прет от того, что ты смог кучку пикселей на экране анимировать и подвигать, тогда прикольнее все самому примитивами сделать.

>да и можно будет плавно перейти на Vulkan
Можешь начать с дх11 и плавно перейти на дх12.
>Нормальных туториалов по D3D11 нет
Есть на ютубе базовые. Есть книга Луны, с самых основ, лежит на либгене, есть книга "Practical Rendering and Computation with Direct3D 11" от трёх авторов.
>>401745
>Хотя много кода полагается на то что если структура unmanaged, то поля будут последовательно (с паддингами если нужно; если LayoutKind.Auto не стоит), так что вряд ли они будут этот момент менять (да и смысл).
Ладно, я обосрался, походу только начиная с .NET 7, unmanaged == blittable:
https://github.com/dotnet/runtime/pull/61759
>Change all "unmanaged" (no GC fields) sequential types to have sequential layout.
>Есть на ютубе базовые. Есть книга Луны, с самых основ, лежит на либгене, есть книга "Practical Rendering and Computation with Direct3D 11" от трёх авторов.
Если искать, то я много раз "слышал": Фрэнка Луна и/или rastertek.
>Можешь начать с дх11 и плавно перейти на дх12.
И ахуеть что там общее только слова в именах API. Я бы поспорил на счёт "плавно перейти на дх12" (так-то "плавно с GL на Vulkan" - тоже немного пиздеш). Я бы в общем описал проблему с D3D12 так: куски D3D11 надо было выкинуть (например, понятия SRV/UAV), а не тащить в низкоуровневое API и не пытаться по-колхозному упростить его (например, старые барьеры). По сравнению с D3D12, D3D11 идеальный API. Я бы мог составить километровый список того что мне не нравится в D3D12 (Vulkan тоже не безгрешен). Ну и как для низкоуровнего API у него слишком мало документации (я вкурсе про отдельные страницы на msdn, 11.3 functional spec, про DirectX-Specs на github и т.д. (можно ещё конечно палочкой потыкать в debug layer чтобы узнать что можно, а что нельзя)). Vulkan с одними только своими Valid Usage секциями ебёт GL/D3D11/D3D12 вместе взятые.
Эти дауны 3 года добавляли описание (там такое описание что лол блять) аргументов в доки для Enhanced Barriers.
Через 20 лет они заметили что у HLSL никакой спеки то и нет.
Точных семантик почти всех операций (D3D12 API и HLSL/DXIL) просто не найти (можно пойти в discord, можно "проверять" debug layer'ом, можно "проверять" undefined behaviour'ом (походу AAA разрабы продолжают так делать), и т.д.).
Пригорело. Просто я только и слышу какой Vulkan хуёвый (примеров мало, extension hell и т.д.), а D3D12 - заебись.
>Просто я только и слышу какой Vulkan хуёвый (примеров мало, extension hell и т.д.), а D3D12 - заебись.
Где ты это слышишь? Весь интернет наполнен красноглазыми дебилами с арчами вулканами впопенсурсами.
Такие дела, малята.
Кто-нибудь может посоветовать хорошие курсы по авалонии?
Лол
спрашивай ии. они тебе какие хошь курсы придумают.
>Пора бы уже
Это по какому признаку "пора"?
Я реально не понимаю.
Да и фидбек от манагеров - показателен.
Когда в конторе какой-то работает чел, который реально на сеньера тянет - его всеми силами пытаются на это место посадить, и потом цепями привязать, чтобы не дай боже - он не ушел. Потому что чел доросший до реального сеньера - это редкий зверь в наше время, и его терять никто не хочет просто так.
>Какой вообще поинт отказываться от юньки
Я слышал, если её используешь, то попадаешь в долговое рабство к разработчикам юньки. Всё это не бесплатно.
>Где ты это слышишь? Весь интернет наполнен красноглазыми дебилами с арчами вулканами впопенсурсами.
Ну так если проигнорировать вскукареки "за Vulkan" (те которые вызваны: fuck Microsoft, fuck Windows, слава опенсурсу, другое (нужное подчеркнуть)).
Я скорее триггернулся на "мертвого говна". D3D11 так то тоже в какой-то степени мёртвый (хотя всякие DLSSы, FSRы и т.д. кинули GL сразу же). Да и по материалам (доки, книги (тут наверное ничья, если не перевес в D3D), ответы на вопросы, йоба-движки на github, презентации (слайды, видео) и т.д.) - у GL и VK их значительно больше чем у D3D11 и D3D12. Корочее выбирая D3D11 - получаешь красивый, логичный API, стабильные драйвера (на пограничных случаях), и т.д. Выбирая GL - получаешь много материала от комьюнити, каждый метод 300 раз обсосанный на stackoverflow, презентации и т.д.

>константный массив
Массив содержащий только константы? Массив являющийся compile-time константой? Что это за зверь такой "константный массив"?
>захочешь объявить константный массив
Зачем?
А он видать не знает что массив это не тип данных, а структура данных и любой массив по определению константный по природе в том плане что чтобы сделать +1 необходимо аллоцировать новый массив.
https://github.com/dotnet/core/discussions/9846
Там есть новая интересная фича языка - Extension members:
https://github.com/dotnet/core/blob/main/release-notes/10.0/preview/preview3/csharp.md#extension-members
У меня его как раз забрали.
>>428021
>Массив содержащий только константы?
Ну типа того. Массив состоящий из констант. Хотя и саму ссылку было бы неплохо защитить, но я о таком даже и не мечтаю.
>Зачем?
Затем что если по замыслу меняться он не должен, то и возможности такой быть не должно, что как бы намекает на его природу тем кто будет читать код. Это элемент того самого самодокументирующегося кода.
>>428026
>чтобы сделать +1 необходимо аллоцировать новый массив
Что ты такое несёшь? По-твоему когда ты элемент массива меняешь весь массив перезаписывается?
>>428009
А как не выйти, когда вместо того чтобы написать просто
const int [] пук = { 1, 2, 3 };
приходится чуть ли не кандарийского демона вызывать
public static readonly System.Collections.Immutable.ImmutableArray<int> пук = System.Collections.Immutable.ImmutableArray.Create<int>(1, 2, 3);

Выглядит как говно. Нахуя нужен дополнительный блок, если без него меньше кода писать надо?
Написано, что она неплохо оптимизирует запросы к postgresql, и с её помощью можно написать гексогональный CQRS с эвент-сорсингом.
Просьба переписать на неё текущие проекты
>Нахуя нужен дополнительный блок
Чтобы вызвать как Extensions.WhereGreaterThan()? Да и вроде логика есть: эти методы должны быть в каком-нибудь классе, да и к тому же extension блок - безымянный.
Походу пизда Extension everything, будет Extension Chleny.
чтобы объявить source же. И внутри этого блока юзать. В примере расширяется свойством.
Так что более правильный вопрос - нахрена нужно это класть в класс Extensions
Впрочем, тут вопрос совместимости. Раньше клал в такие классы - и теперь будешь класть, докладывать.
хотя до котлин им еще очень очень бесконечно далеко.
>И внутри этого блока юзать
хуйня какая-то, просто всё вправо сдвинули. Мне вообще не в падлу было писать this IEnumeable<T> self
>public static readonly System.Collections.Immutable.ImmutableArray<int> пук = System.Collections.Immutable.ImmutableArray.Create<int>(1, 2, 3);
Ты в Блокноте код пишешь? Угашенный ты об клавиатуру. Любая IDE подскажет, как упростить код.
>хотя до котлин им еще очень очень бесконечно далеко.
Котлин невыразительный очень. У C# приемущество в выразительности, поэтому им и пользуемся
Гайз, я нашёл классную библиотеку https://github.com/jbogard/MediatR
Написано, что можно забыть про то, чтобы регистрировать сервисы в DI и просто сделать, чтобы всё было командой. Даже не надо думать, какой сервис её обработает, всё автоматически происходит
автошиттер и мудятор юзают только конченые имбецилы.
Эти библиотеки были написаны имбецилом, у которого за спиной ни одного нормального реализованного проекта.
Вменяемые гайзы давно используют тримминг и АОТ, в то время как имбецильные пользователи аутопупера и мордатыра плачут над последствиями тормознутой рефлексии.
Какое счастье, что эти библы стали платными! Наконец-то тупорылые джуниоры перестанут тянуть их в проекты. Код станет чище, проще, быстрее.
Я сам раньше был против, но теперь, я решил переписать свои проекты на медиатор, потому что это самый быстрый способ перевести проект на GOOD PRACTICES, в том числе на чистую архитектуру.
Ничего не нужно делать, медиатор и автомаппер всё делает за тебя. Сам открывает транзакцию, сам её закрывает. Мне только остаётся добавить один класс DTO, а все свойства прокидываются в БД через маппер сами. ДБОхи создаются на лету через генерацию IL.
Все доменные события запускаются из бехеивиоров. Все подписчики работают автоматически, мне вообще код писать не надо.
То есть, у меня вообще весь код это поток доменных событий, которые сами собой всё делают.
Нахуя я раньше писал код руками - был долбоёбом.
а ты не делай так. не меняй содержимое массива. ты знал куда шёл. не нравится - пиши на синклер бейсике )
на деле я главный хейтер шарпа в этом треде (из шарпистов), и про списки/массивы особенно.
он не продуман. делали "своя жава с блэкджеком и шлюхами, но все же жава"
Из-за этого родили кучу тупых решений - статические нерасширяемые классы, примитивные модификаторы видимости, убогие енумы, тупые event на уровне языка, зато обломались сохранить Contract, бардак в коллекциях (нет нормального разделения на мутабельные, иммутабельные и так далее), забыли про IReadOnlyList (хотя он мегаочевиден), null safety (вернее его отсутствие), необходимость new, и так далее и так далее и так далее.
даже вот фича следующего релиза языка - расширения. мол можно новый синтаксис который позволит сделать расширение даже свойством (и может даже статические классы расширять - тут не очень явно будет ли это (скорее всего нет))
Вопрос - а сразу нельзя было сделать? Что мешало то? То, что методы расширения это статические методы? Так стоп. Для расширения статического класса и нужно статический метод. А для расширения свойствОМ ...нужны методы, ведь свойство это просто сахар для 2х методов.
то есть соблюдены все условия, но почему то расширение сделали только методами и только инстансов просто потому что....потому что гладиолус, других причин нет кроме рукожопости.
и теперь этот выразительный язык будет иметь ДЖВА синтаксиса для расширений. Выразительность х2 )))
> ДЖВА синтаксиса для расширений
да и похуй
> убогие енумы
единственно правильные энумы, всё остальное это не энумы
> статические нерасширяемые классы
долбоёб, что-ли? статика по определению не расширяемая. Или надо как в котлине на лету инстансы статических классов создавать, чтобы тебе удобно было?
> бардак в коллекциях
идеальный порядок
> А для расширения свойствОМ ...нужны методы, ведь свойство это просто сахар для 2х методов.
Типо, делаешь свойство расширения, и где-то в залупьем классе, который сконпелировали 4 года назад появится его бекфилд? ты долбоёб?
> для расширения статического класса и нужно статический метод
Ага, да, this ещё не помешает в статическом классе
Короче, ты прямо тупой какой-то, у тебя всё в голове смешалось, ты даже не понимаешь, чем энам от объекта отличается
>да и похуй
и то верно, ведь это ж выразительнее. хочешь так, хочешь этак выражайся )
на деле выразительность это способность лаконично и изящно выразить функционал, но кого это волнует )
>статика по определению не расширяемая
как и инстансы этих самых классов. Однако функционал расширения почему то существует. И при этом эти методы расширения сами по себе статические методы ))
>как в котлине на лету инстансы статических классов создавать
я специально не упоминал котлин. А так да - много фич из котлина хотел бы видеть в шарпе.
>идеальный порядок
ну когда чел сидит в куче говна и говорит "идеально"....ну тут я не знаю что такому человеку возразить. Поэтому тут ничего не скажу.
>который сконпелировали 4 года назад появится его бекфилд? ты долбоёб?
вы там определитесь уже кто из вас долбоеб. Ты или мс, которые вот в следующем шарпе приносят именно добавление свойства расширения )))
>Ага, да, this ещё не помешает в статическом классе
кэп намекает (вернее орет как ненормальный) что как бы можно не использовать this для методов расширений НЕ инстанса.
но зачем слушать кэпа. ведь у нас тут целый анон
>чем энам от объекта отличается
енам это алиса для инта. Причем кривой. А других енамов не завезли. Тут же вам не расты )
>енам это алиса для инта
Это единственное, с чем я согласен.
А так ты долбоёб, который застрял на уровне синтаксисов язычков, тебе не светит ничего большего чем говнокодить и ныть
ну против такого "профессионального" аргумента упоротого шарписта сложно возразить )
>Вопрос - а сразу нельзя было сделать?
Ну так возьми язык в котором все это с самого начала есть и не страдай.
да, а что? а ты пашешь в субботу?
>Как это отвечает на вопрос и оправдывает рукожопость авторов шарпа?
Да - никак. Но поинт был не в этом. Все те проблемы которые ты описал не волнуют большинство тех кто пользуется шарпами, а тебе они причиняют истинную попоболь. Если ты не мазохист, то логичнее было бы переключиться на язык в котором этих проблем нет и забыть про шарп.
Я понимаю если бы это был js, который литерали понополист в своей нише и приходится терпеть. Но шарп даже не лидер рынка в своей области. Зачем страдать, мистер Андерсен?
>забыли про IReadOnlyList (хотя он мегаочевиден)
Кому он нахуй нужен чел. IReadOnlyCollection
Честно у тебя какие-то странные претензии уровня "я ебанутый шизофреник". Шарп это один из самых приятных языков с невероятно гибкой платформой которая является его частью, а не как у джавы выпердыш сбоку.
>не волнуют большинство
ну и пусть радуются. крудошлепы и прочие галерщики пусть живут в своем мирке.
Мне то ЗАЧЕМ на них равняться?
>логичнее было бы переключиться на язык
с чего это вдруг? я не только жалуюсь, я и активно предлагаю как да что. И да, я пишу не только на шарпе, потому что "каждой задаче свой инструмент". Для андрюши возьму котлин,а не замарин. Для ML питончик.
>Зачем страдать, мистер Андерсен?
зачем жрать говно и радоваться, мистер Смит? Можно принять недостатки, но можно и не принимать, а заменить на адекватные решения (и добиться чтобы это внесли в шарп, и ведь вносят же - те же рекорды с трудом выбили чтобы их внесли. Или те же field, а вот уже и расширение пропертями). Зачем не стремиться к этому и жрать что дали, агент Смит? да еще и тыкать пальцем в тех, кто не радуется говноедству.
>>429645
>Кому он нахуй нужен чел.
тем, кто чуть чуть поднялся выше уровня говношлепа и понимает что такое контрактное программирование и вообще основы чистого кода.
>Шарп это один из самых приятных языков
это не значит что он хорош в выразительности. Котлин по выразительности порвет шарп как тузик. Шарп растет в выразительности почуть, но весьма странно и ДОЛГО.
>Мне то ЗАЧЕМ на них равняться?
Напиши свои коллекции, делов-то. Я думаю, как только ты перестанешь ныть и займёшься делом - сразу поймёшь, почему в дотнете именно такая иерархия наследования. Заодно разберёшься.
> я не только жалуюсь, я и активно предлагаю как да что
ты предлагаешь какие-то дебильные идеи на дваче. Честно, со стороны ты выглядишь как дурачёк, который код не читает, но осуждает. Я надеюсь, ты такие мысли не озвучиваешь на работе.
> но можно и не принимать, а заменить на адекватные решения
Ты удивишься, но то, что ты считаешь адекватными решениями, многие могут обоссать. В разработке много субъективщины, и ты почему-то решил, что вот именно твоё видение правильное, опять же, не разобравшись.
Тут был дурачёк один, он примерно то же самое говорил, что и ты. он тупо не понял, как работать с IDisposable и пытался подружить события и многопоточке. В итоге из-за того, что у него не было БАЗЫ, у него нихуя не работало, а винил он во всём дотнет.
Мы его отправили заниматься пейтоном. Там он приживётся, там все такие.
>Напиши свои коллекции
дык и пишу. и не я один пишу
свои реализации ObservableCollection тому пример. Почему то в нем нет AddRange, а Add его не заменяет и потому люди пишут своё.
Также написание своих коллекций не решает фундаментальных проблем необходимости костылей когда у нас IList, а принимают IReadOnlyList и мы должны засорять код мусором.
Ну и конечно никак не могут сделать byte[] иммутабельный/ридонли. "нинужно" орут некоторые. Мол, он используется в разных там нутрях и далеко не уходит. Странно, а вот ReadOnlySpan почему то существует, хотя еще более узко применяется.
>почему в дотнете именно такая иерархия наследования
И почему же? А ну давай расскажи мне.
Ах да, потому что ПОЗДНО добавили IReadOnlyList и НЕ СМОГЛИ его впихнуть куда надо из-за бинарной совместимости, и ТОЛЬКО ПОЭТОМУ.
Я специально выделил главное. А то находятся додики, что начинают рассказывать про правильность иерархии и что мол IList не должен наследовать IReadOnlyList и прочий бред сивой кобылы.
Я подчеркиваю еще раз - даже мс считает что ДОЛЖЕН, просто это ломало бинарную совместимость и потому вкрутили куда вкрутили.
>Честно, со стороны ты выглядишь как дурачёк, который код не читает, но осуждает
мне поплевать что обо мне думают всякие крудошлепы, я уже сказал. И на работе озвучиваю и в тредах гихаба на тему развития шарпа тоже. Я человек, который критикует и думает о развитии языка. И смешно даже когда мне всякие орут "ты ничего не понимаешь, это нинужно и правильно именно так", а потом мс бац и реализует. Ты один из таких - так что мне поплевать как я для тебя выгляжу.
>Ты удивишься, но то, что ты считаешь адекватными решениями, многие могут обоссать.
быдло может обоссать вообще без причин. мне теперь переживать о том, что оно думает?
>и ты почему-то решил, что вот именно твоё видение
мое? разве мое? я просто озвучил его, но это не значит что оно только мое. про null помнишь? а потом бац и втащили его в шарп. Хотя вроде бы зачем, ведь "крикуны типа меня" нихрена не понимают )))
>3429830
нет. в proposal и прочем.
А тут тред чисто для помолчать что ли?
>Напиши свои коллекции
дык и пишу. и не я один пишу
свои реализации ObservableCollection тому пример. Почему то в нем нет AddRange, а Add его не заменяет и потому люди пишут своё.
Также написание своих коллекций не решает фундаментальных проблем необходимости костылей когда у нас IList, а принимают IReadOnlyList и мы должны засорять код мусором.
Ну и конечно никак не могут сделать byte[] иммутабельный/ридонли. "нинужно" орут некоторые. Мол, он используется в разных там нутрях и далеко не уходит. Странно, а вот ReadOnlySpan почему то существует, хотя еще более узко применяется.
>почему в дотнете именно такая иерархия наследования
И почему же? А ну давай расскажи мне.
Ах да, потому что ПОЗДНО добавили IReadOnlyList и НЕ СМОГЛИ его впихнуть куда надо из-за бинарной совместимости, и ТОЛЬКО ПОЭТОМУ.
Я специально выделил главное. А то находятся додики, что начинают рассказывать про правильность иерархии и что мол IList не должен наследовать IReadOnlyList и прочий бред сивой кобылы.
Я подчеркиваю еще раз - даже мс считает что ДОЛЖЕН, просто это ломало бинарную совместимость и потому вкрутили куда вкрутили.
>Честно, со стороны ты выглядишь как дурачёк, который код не читает, но осуждает
мне поплевать что обо мне думают всякие крудошлепы, я уже сказал. И на работе озвучиваю и в тредах гихаба на тему развития шарпа тоже. Я человек, который критикует и думает о развитии языка. И смешно даже когда мне всякие орут "ты ничего не понимаешь, это нинужно и правильно именно так", а потом мс бац и реализует. Ты один из таких - так что мне поплевать как я для тебя выгляжу.
>Ты удивишься, но то, что ты считаешь адекватными решениями, многие могут обоссать.
быдло может обоссать вообще без причин. мне теперь переживать о том, что оно думает?
>и ты почему-то решил, что вот именно твоё видение
мое? разве мое? я просто озвучил его, но это не значит что оно только мое. про null помнишь? а потом бац и втащили его в шарп. Хотя вроде бы зачем, ведь "крикуны типа меня" нихрена не понимают )))
>3429830
нет. в proposal и прочем.
А тут тред чисто для помолчать что ли?
>ДОЛЖЕН
найди любой другой язык, которому больше пяти лет без проблем. На нём либо проекты не пишут, либо всё примерно ещё хуже.
Давай вот прикинем:
- мутабельность всего в джаве, её ебанутые исключения и еще более упоротые костыли для работы с коллекциями, обоссаный спринг
- кресты, в которых вообще полный пиздец и люди молятся, чтобы в очередной раз жопу себе не прострелить
- JS/python/PHP, которые вообще никак не проектировали и они просто стихийно получились
Мне дотнет нравится, а то, что там видите-ли IReadOnlyList/IList можно было лучше сделать - так это ты с жиру бесишься.
Это абсолютно нормально на специфичных проектах свои примитивы коллекций использовать. Мы вот писали свой UiThreadCollection, потому что он нам подходил, а ObservableCollection не подходил.
>Давай вот прикинем
>python
ты видимо мало писал на питоне. там хватает WTF, но у него шикарная основная задумка.
жс был для вебстраничек ТОГО времени
пхп вообще "нам надоел перл, а надо странички делать"
кресты - там и так понятно. специфика
жава - ну вот ее шарп и копировал, причем бездумно. перетащил new, коллекции, null и прочее.
>так это ты с жиру бесишься.
учитывая что иммутабле и фрозен стали частью дотнета, не зря бешусь. А то велосипеды, велосипеды.
>специфичных проектах свои примитивы коллекций использоват
ключевое слово специфичных. Да и не сделаешь ты ридонли byte[] никак. Ну вообще никак. Ну то есть совсем никак. С рождением Span стало полегче (еще бы его везде принимали, а то не одна итерация еще пройдет пока дотнет будет везде иметь перегрузки в span, про сторонний код вообще молчу)
>ObservableCollection не подходил
а если бы подошел, то писать не пришлось (с) кэп
так может все же сделать ObservableCollection более правильным?
Например, добавить AddRange и прочие методы, которые реально нужны всем. Да не, бред какой то )))
К IReadOnlyList я придираюсь потому что я сторонник чистого кода - если нужно перечислять, то я приму IEnumerable, если нужно читать список, то IReadOnlyList, а где надо там вообще иммутаблы.
У меня глаз дергается когда народ забивает и везде гоняет IList (а еще защитные копии создает)
Я понимаю что есть решения где "ну поздно всрались" - null safety, IReadOnlyList, new...но есть же куча вещей которые можно улучшить без потери бинарной совместимости. И не растягивать на несколько итераций как со свойствами, рекордами и вот с расширениями (небось оно не будет уметь статик расширять и через несколько версий дотнета и это добавят отдельным особым синтаксисом ДЛЯ ВЫРАЗИТЕЛЬНОСТИ ))))
Но мс прогибать трудно. Они никогда не сделают аттрибут для рослина чтобы он делал ConfigureAwait(false), никогда не добавят тип Unit (который каждый плодит свой велосипед одинаковой реализации, но это все равно разные типы), видимо никогда не сделают Discriminated Unions (который просят постоянно), да и primary constuctors они сделали примитивно (видимо не было языков где можно было подсмотреть))) и тоже никогда не исправят.
И я осуждаю такой подход мс. Нужно копировать удачные решения с других языков, а не выделываться и быть нетакусиками. Шарп хорош, но мог бы быть еще лучше. Вот просто мог бы....если бы просто сначала думали, а потом делали.
>Давай вот прикинем
>python
ты видимо мало писал на питоне. там хватает WTF, но у него шикарная основная задумка.
жс был для вебстраничек ТОГО времени
пхп вообще "нам надоел перл, а надо странички делать"
кресты - там и так понятно. специфика
жава - ну вот ее шарп и копировал, причем бездумно. перетащил new, коллекции, null и прочее.
>так это ты с жиру бесишься.
учитывая что иммутабле и фрозен стали частью дотнета, не зря бешусь. А то велосипеды, велосипеды.
>специфичных проектах свои примитивы коллекций использоват
ключевое слово специфичных. Да и не сделаешь ты ридонли byte[] никак. Ну вообще никак. Ну то есть совсем никак. С рождением Span стало полегче (еще бы его везде принимали, а то не одна итерация еще пройдет пока дотнет будет везде иметь перегрузки в span, про сторонний код вообще молчу)
>ObservableCollection не подходил
а если бы подошел, то писать не пришлось (с) кэп
так может все же сделать ObservableCollection более правильным?
Например, добавить AddRange и прочие методы, которые реально нужны всем. Да не, бред какой то )))
К IReadOnlyList я придираюсь потому что я сторонник чистого кода - если нужно перечислять, то я приму IEnumerable, если нужно читать список, то IReadOnlyList, а где надо там вообще иммутаблы.
У меня глаз дергается когда народ забивает и везде гоняет IList (а еще защитные копии создает)
Я понимаю что есть решения где "ну поздно всрались" - null safety, IReadOnlyList, new...но есть же куча вещей которые можно улучшить без потери бинарной совместимости. И не растягивать на несколько итераций как со свойствами, рекордами и вот с расширениями (небось оно не будет уметь статик расширять и через несколько версий дотнета и это добавят отдельным особым синтаксисом ДЛЯ ВЫРАЗИТЕЛЬНОСТИ ))))
Но мс прогибать трудно. Они никогда не сделают аттрибут для рослина чтобы он делал ConfigureAwait(false), никогда не добавят тип Unit (который каждый плодит свой велосипед одинаковой реализации, но это все равно разные типы), видимо никогда не сделают Discriminated Unions (который просят постоянно), да и primary constuctors они сделали примитивно (видимо не было языков где можно было подсмотреть))) и тоже никогда не исправят.
И я осуждаю такой подход мс. Нужно копировать удачные решения с других языков, а не выделываться и быть нетакусиками. Шарп хорош, но мог бы быть еще лучше. Вот просто мог бы....если бы просто сначала думали, а потом делали.
>я сторонник чистого кода
петух ты, я же тебе говорил
> У меня глаз дергается когда народ забивает и везде гоняет IList
Это намеренно делается. Если знаешь, что метод возвращает List - не еби мозги, и верни List.
> new
А что с нью не так?
> не сделают аттрибут для рослина чтобы он делал ConfigureAwait(false)
И не надо
> тип Unit
нах не нужен, просто верни new object(), он сериализуется в бочку {}
>И я осуждаю
ты ноешь просто
>А что не так с null
Гм, есть еще те, кто не знает? погугли "Ошибка на миллиард долларов"
>>429988
>петух ты, я же тебе говорил
А я про тебя ничего не говорил, но говорил про быдло. Похоже, что ты и есть то самое было.
>метод возвращает List - не еби мозги, и верни List.
метод ПРИНИМАЕТ. Что возвращать - уже совсем другой вопрос.
>А что с нью не так?
ничего. просто синтаксический мусор. Видимо из-за PascalCasing (но скорее всего просто потому что копировали жаву и не заморачивались), как и ;
>нах не нужен, просто верни new object(), он сериализуется в бочку {}
очевидно ты вообще не в курсе где нужен этот Unit. Он нужен в Task<Unit> и прочей реактивности. Без него ты будешь вынужден делать ДВЕ реализации одного и того же - для Task и Task<T>. А поскольку это лютый гемор и дублирование кода, то разрабы либ вводят свой Unit. Жетбраинс например. Или тот же "всеми любимый" тут медиатр
>ты ноешь просто
я критикую. но мои оппоненты просто говноеды которые даже не понимают сути проблемы. Или у них синдром утенка или....они просто не доросли, шлепают себе там "работает и ладно".
> Они никогда не сделают аттрибут для рослина чтобы он делал ConfigureAwait(false),
И это правильно. Не должно быть ситуаций, когда один и тот же код ведет себя по разному в зависимости от настроек проекта
> Что возвращать - уже совсем другой вопрос.
на вход принимай List, а на выходе делай List
> Без него ты будешь вынужден делать ДВЕ реализации одного и того же - для Task и Task<T>
Если нужно две реализации, делай две реализации.
> которые даже не понимают сути проблемы.
не, я просто пользуюсь лучшим языком из существующих, и голову не грею себе проблемами.
> нытьё
Если ты ебёшь себе и всем окружающим мозги дилеммой о том, что же вернуть IReadOnlyList или IReadOnlyCollection - ты просто задрот.
Из того факта, что ты задрот не следует, что все вокруг "шлепают себе там "работает и ладно"". Я для себя такие мелочи давно разобрал, и пытаюсь решить реальные проблемы, в частности, у моего апи 300 тысяч пользователей, и проблемы с производительностью.
А ты дальше задротствуй, решай свои проблемы с "чистым кодом".
>когда один и тот же код ведет себя по разному в зависимости от настроек проекта
да ты мне расскажи )
аттрибуты сборки [assembly: ...] именно для этого и придуманы
это же не флаги компилятора.
Сейчас приходится использовать Fody, но он, очевидно, добавляет оверхеда в компиляции.
>>430037
>на вход принимай List
за такую только мысль меня палками погонят с работы программиста. Это настолько пахнет, что даже воняет.
Ты такое на работе не предлагай. Я серьезно. Хотя....если у вас это норма...
>Если нужно две реализации, делай две реализации.
Кому нужно?
И это не две реализации. Это ИДЕНТИЧНАЯ реализация буквально копипаст, из которой убирают просто <T>. Само собой, заниматься таким идиотизм, поэтому вводят Unit.
Вот посмотри на этих ребят https://learn.microsoft.com/en-us/previous-versions/dotnet/reactive-extensions/hh211727(v=vs.103)
Почему то они не хотят делать две реализации. Видимо тупые )
>я просто пользуюсь лучшим языком из существующих
Из твоей выборки в которой 1.5 языка причем 0.5 это жс?
>Если ты ебёшь себе и всем окружающим мозги дилеммой о том
так проходи мимо. какого хера ты мне пишешь. я высказался по теме, по которой много кто высказаывался и даже сами разрабы шарпа
ты всех обосрал типа ты дартаньян и еще кого то поучаешь лол
я и буду решать, просто с тобой спорить не буду. Не с руки мне спорить с тем, кто "передавай List возвращай List" и "мне норм яскозал". Это говношлеп 9999 левела. Будет сложно различать кто есть кто (ибо тут все аноны), но страдающему синдромом утенка отвечать не буду.
>когда один и тот же код ведет себя по разному в зависимости от настроек проекта
да ты мне расскажи )
аттрибуты сборки [assembly: ...] именно для этого и придуманы
это же не флаги компилятора.
Сейчас приходится использовать Fody, но он, очевидно, добавляет оверхеда в компиляции.
>>430037
>на вход принимай List
за такую только мысль меня палками погонят с работы программиста. Это настолько пахнет, что даже воняет.
Ты такое на работе не предлагай. Я серьезно. Хотя....если у вас это норма...
>Если нужно две реализации, делай две реализации.
Кому нужно?
И это не две реализации. Это ИДЕНТИЧНАЯ реализация буквально копипаст, из которой убирают просто <T>. Само собой, заниматься таким идиотизм, поэтому вводят Unit.
Вот посмотри на этих ребят https://learn.microsoft.com/en-us/previous-versions/dotnet/reactive-extensions/hh211727(v=vs.103)
Почему то они не хотят делать две реализации. Видимо тупые )
>я просто пользуюсь лучшим языком из существующих
Из твоей выборки в которой 1.5 языка причем 0.5 это жс?
>Если ты ебёшь себе и всем окружающим мозги дилеммой о том
так проходи мимо. какого хера ты мне пишешь. я высказался по теме, по которой много кто высказаывался и даже сами разрабы шарпа
ты всех обосрал типа ты дартаньян и еще кого то поучаешь лол
я и буду решать, просто с тобой спорить не буду. Не с руки мне спорить с тем, кто "передавай List возвращай List" и "мне норм яскозал". Это говношлеп 9999 левела. Будет сложно различать кто есть кто (ибо тут все аноны), но страдающему синдромом утенка отвечать не буду.
>на питоне. там хватает WTF, но у него шикарная основная задумка
Это какая - ебучие отступы как элемент синтаксиса? Это вообще одна из самых наихуевейших идей в дизайне ЯП.
по ии учи. по нескольким сразу. прося их погуглить, а не выдать фуфел.
>ридонли byte[]
Если тебе не надо менять значения в массиве - просто берешь и не меняешь.
Я вот уверен, что даже если в шарпе появится такой массив, то ты все равно будешь ныть, что его можно поменять, через рефлексию, интеропы или еще какой-нибудь ансейф.
>Нужно копировать удачные решения с других языков, а не выделываться и быть нетакусиками
Создателям голанга из гугла расскажи. Вот где нетакусики. Причем не просто выебываются делая обычные вещи непривычным способом, но еще и ебанутые теории под это сочиняют
питон динамический язык. Все есть объект и объект этот словарь. А еще есть методы. И базовые конструкции языка типа for in len del и так далее. И дандер методы. И декораторы которые тоже методы и методы возвращают. То есть язык построен вокруг этой базовый концепции, даже ооп прикручен сбоку по этому же принципу (от чего у любителей истинного ооп бомбит, но так язык не для них). Простая система импортов. И тем самым получается стройный единообразный код и шикарный клей. Он ведь не единственный язык на свете, но основным клеем для всего стал именно он.
А отступы....ну когда вставляешь чужой код, то фу. А вот когда читаешь чужой код, то "слава тебе господи, что не руби какой то"
>просто берешь и не меняешь.
так везде можно сказать "просто не меняйте". А то всякие там интерфейсы IReadOnly придумывают. Странные люди.
>что его можно поменять, через рефлексию
поменять можно все. я НЕ запрещаю менять. Я просто хочу четко объявлять в сигнатуре что мне нужно только читать. Для этого и вводили IReadOnly*. Не потому что где то не работало, а чтобы можно было ЯВНО указать что "вы мне передадите список и я его буду только читать". Потому что читать сигнатуру - тру, а читать чужой код выискивая "а не изменят ли мой список сейчас, да и в будущем нужно 100500 раз забежать посмотреть" - не тру. Контракт класса для этого и нужен.
>>430123
>Создателям голанга из гугла расскажи.
ну они просто упоротые. сам я го обхожу стороной. я изучал более 10 языков, но го даже не трогаю. я просто глянул на их import "fmt" или []byte и спросил себя "а зачем так делать? зачем отличаться от привычных подходов". Ответ был для меня очевиден и эпопея с дженериками только убедила.
Я вот искренне не понимаю в чём сложность сделать
const int []
Компилятор видит ключевое слово const и делает себе пометку выдавать ошибку при каждой записи в такой массив. В чём тут проблема?
мимо
>А то всякие там интерфейсы IReadOnly придумывают. Странные люди.
У тебя прям жёсткое непонимание. Нет ни одной структуры данных которая бы дала гарантии неизменности объекта внутри.
ReadOnly относится к изменению самой структуры списка, то есть нельзя удалить или добавить. При этом ты все ещё можешь перезаписать значение. Есть readonly который относится к ссылке на объект, но не существует в природе способа создать незаменимый участок памяти.
Любой массив это структура только для чтения, но при этом его элементы можно менять как угодно. Массив констант невозможен потому что любой язык при компиляции или транспиляции просто вставит значение константы во все места использования.
Тебе бы блять обратно на первый курс университета где объясняют как память и процессор работает и чем стек от кучи отличается.
>за такую только мысль меня палками погонят с работы программиста
Всем похуй, что ты там себе назапрещал. категоричность верный признак долбоёба
игнорирование базовых принципов чистого кода - еще больший идиотизм.
Рекомендации по чистому коду не просто так рождаются. А потому что иначе получается лапша из говна.
Потом проект или загибается или виновник сваливает с проекта (часто и с работы), а за ним приходится это говно разгребать
зато он не долбоеб - насрал и свалил. Знали бы на работе, что он такой "не долбоеб" - не брали бы даже. Ну разве туда, где такие же долбоебы или пишут на отъебись.
константа она вшивается в IL и как бы это не то же самое, что объект в кучке.
есть исключение правда. если задать то ли спан то ли что еще (вот не записал) для байтов, то в рослине есть правило чтобы он принял это и юзал без аллокаций как то. Я видел это в кишках дотнета или его либ.
>>430178
>У тебя прям жёсткое непонимание.
это ты ничего не понял. я не требую гарантии неизменности. Я требую гарантии компилятора. Fail-Fast во все поля. Зачем ловить проблему в рантайме, если ее отловить можно еще на уровне компиляции.
null safety тому ярчайший пример. С ним не нужно проверять каждый параметр на null - об этом позаботится компилятор. Достаточно лишь на границе проверить и всё. Точно так же компилятор укажет на ошибку когда nullable передаешь не туда. Это сильно снижает ошибки NRE
Есть правило чистого кода - метод должен принимать как можно общий тип (возврат вообще другая тема).
И если у тебя нет подходящего общего типа, то значит компилятор тебе ничем не поможет.
Допустим тебе нужно IReadOnlyList, но у тебя нет его, поэтому ты принимаешь IList, как всегда. Это вызывает необходимость вызывателя этого кода разбираться можно ли ему передать список, или лучше сделать копию, или враппер, или ничего не делать,а класс внутри делает.
Ну а автор этого кода - там этот массив может укатиться далеко по уровням, а через год он (или другой чел) где то в глубине и знать не будет что в этот список писать нельзя. Конечно нормальный программист не будет делать особых глупостей, но тред показал что нормальность понятие растяжимое и я лучше доверюсь компилятору, чем сам буду разбираться что можно, а что нет. Нарушение контракта просто не должно компилироваться. Собственно поэтому IReadOnly* и ввели, просто потому что по хорошему оно надо и должно было быть изначально. И я активно им пользуюсь.
И да, такое бы неплохо было и на уровне чистого массива. Вот как спаны же имеют ридонли вариант, вот так и массивы могли бы. Причем физически они те же самые, просто компилятор бы не давал писать. Или вот как scoped запрещает утаскивать из метода.
Если коллекции продуманы сразу - то есть мутабельные, риоднли, иммутабельные, фрозен, правильная иерархия интерфейсов, то не нужно "ну так не пиши в массив" и других костылей.
По хорошему все должно быть по дефолту не null, ридонли, запечатанное и так далее.
А в шарпе ровно наоборот.
константа она вшивается в IL и как бы это не то же самое, что объект в кучке.
есть исключение правда. если задать то ли спан то ли что еще (вот не записал) для байтов, то в рослине есть правило чтобы он принял это и юзал без аллокаций как то. Я видел это в кишках дотнета или его либ.
>>430178
>У тебя прям жёсткое непонимание.
это ты ничего не понял. я не требую гарантии неизменности. Я требую гарантии компилятора. Fail-Fast во все поля. Зачем ловить проблему в рантайме, если ее отловить можно еще на уровне компиляции.
null safety тому ярчайший пример. С ним не нужно проверять каждый параметр на null - об этом позаботится компилятор. Достаточно лишь на границе проверить и всё. Точно так же компилятор укажет на ошибку когда nullable передаешь не туда. Это сильно снижает ошибки NRE
Есть правило чистого кода - метод должен принимать как можно общий тип (возврат вообще другая тема).
И если у тебя нет подходящего общего типа, то значит компилятор тебе ничем не поможет.
Допустим тебе нужно IReadOnlyList, но у тебя нет его, поэтому ты принимаешь IList, как всегда. Это вызывает необходимость вызывателя этого кода разбираться можно ли ему передать список, или лучше сделать копию, или враппер, или ничего не делать,а класс внутри делает.
Ну а автор этого кода - там этот массив может укатиться далеко по уровням, а через год он (или другой чел) где то в глубине и знать не будет что в этот список писать нельзя. Конечно нормальный программист не будет делать особых глупостей, но тред показал что нормальность понятие растяжимое и я лучше доверюсь компилятору, чем сам буду разбираться что можно, а что нет. Нарушение контракта просто не должно компилироваться. Собственно поэтому IReadOnly* и ввели, просто потому что по хорошему оно надо и должно было быть изначально. И я активно им пользуюсь.
И да, такое бы неплохо было и на уровне чистого массива. Вот как спаны же имеют ридонли вариант, вот так и массивы могли бы. Причем физически они те же самые, просто компилятор бы не давал писать. Или вот как scoped запрещает утаскивать из метода.
Если коллекции продуманы сразу - то есть мутабельные, риоднли, иммутабельные, фрозен, правильная иерархия интерфейсов, то не нужно "ну так не пиши в массив" и других костылей.
По хорошему все должно быть по дефолту не null, ридонли, запечатанное и так далее.
А в шарпе ровно наоборот.
много написал и забыл
чем уже я укажу контракт - тот же IList, тем больше я требую от клиента моего кода для удовлетворения контракта, а мне мутабельность и не нужна вовсе. У клиента может быть коллекция самопал и реализовывать IReadOnlyList, а передать мне он ее не может потому что я требуют больше нужного. В итоге клиенту придется лепить костыли ради "да просто так".
А автор класс через время - оооо, я ж просил IList, значит никто не будет удивлен если я него запишу. И перекомпилировать никому не нужно даже, лепота. С очевидным результатом.
>и как бы это не то же самое, что объект в кучке
А как это мешает?
Я конечно понимаю что при передачи в метод или возврате из него передаётся ссылка, а она сама по себе не содержит информацию о том что это константа или нет. Я не спец по компиляторам, но комон, эту проблему уж можно как-то разрулить.
ну эти данные они ж в нативной памяти получаются в образе длл что в память грузится. GC с таким работать не может. То есть надо будет все равно в рантайме в кучку положить - так проще запретить юзеру такие константы чем учить рантайм загонять такие массивы в кучу.
с другой стороны, те же стринги в константы можно. То есть технически можно, но некому делать значит.
> за такую только мысль меня палками погонят с работы программиста
> игнорирование базовых принципов чистого кода - еще больший идиотизм.
> Потому что читать сигнатуру - тру, а читать чужой код выискивая
Никто тебя никуда не погонит, ты сам себе напридумывал правил чистого кода, которых в оригинальной книжке нет. Если ты везде возвращаешь (принимаешь) очень точные типы, ты даёшь очень много ненужных подробностей тому, кто твой код читает. Коллеги будут ломать голову, нахера ты так приседал, чтобы запретить чего-то менять в массиве из десяти байтов, и будут писать .ToList() .ToList() .ToList() через каждую строчку
> Я вот искренне не понимаю в чём сложность сделать const int []
> Компилятор видит ключевое слово const
Во время исполнения это работать не будет.
Во время компиляции это тоже не будет работать, потому что этот конст надо пропихивать во все методы, во все использования. А это для языка фича уровня 5 лет утверждать синтаксис.
Вердикт:
Ты всё еще петух, и твоё мнение лучше при себе держать
const string/int/float это просто сахар. Значение переменной будет вставлено в код на месте переменной.
> Я вот искренне не понимаю в чём сложность сделать const int []
И что это означает? int [] { 1, 2, 3, } вот тебе массив констант. Что должен делать твой пример?
какой еще книжке. Чистый код это не значит книжка "чистый код", бестолочь. Это вообще набор разных концепций позволяющих не писать как ты. Как и с паттернами это не только "банды четырёх (GoF)"
Вот тебе по тупой морде https://learn.microsoft.com/en-us/dotnet/standard/design-guidelines/parameter-design
"✔️ DO use the least derived parameter type that provides the functionality required by the member.
For example, suppose you want to design a method that enumerates a collection and prints each item to the console. Such a method should take IEnumerable as the parameter, not ArrayList or IList, for example."

И если неуч начнет "там перепечатка старой редакции книги, в третьей всё поменялось", то вот ему по морде третьей редакцией где прямо говорится "не использовать List<T>"
Конечно там есть ремарка, что это не должно влиять на перфоманс и иногда нужно принять как можно более конкретный тип. Но это и уводит нас к претензии что "мы должны передать byte[], чтобы избежать виртуальных вызовов, но у нас нет ридонли версии, поэтому мы должны ВЕРИТЬ в то, что передача мутабельного типа безопасна". Гарантии "мамой клянусь" может кого то и устраивают, но гарантиями по факту не являются.
Span не предлагать. Если метод принимает byte[], то ему приходится передавать byte[]
>чего с тебя взять?
научиться у меня, как у очевидно куда более опытного и стать просвещенным гуру.
хотя чему бестолковый крудошлеп может научиться )
ps: быдланские трололо на дваче действуют только на школоту. Так что зря буковки тратишь.
>Я вот искренне не понимаю в чём сложность сделать
>const int []
Потому что константы вообще не так в шарпе работают.
>Потом проект или загибается или виновник сваливает с проекта
Так переживаешь, как будто это твои личные коды, а не кабана.
Ну и насчет разгребать, иногда гораздо проще разгрести написанное просто и в лоб по принципу "работает - работайте", чем разбираться в тоннах абстракций над абстракциями над абстракциями.
Какая разница чей код, если мне геморрой от этого.
>чем разбираться в тоннах абстракций над абстракциями над абстракциями.
назвать переменную не х, а нормально - не абстракция
принять нормальный тип - не абстракция
ну и так далее.
> принять нормальный тип - не абстракция
да ты заебал, очевидно, что правильно везде возвращать IEnumerable<T> , потому что пользователям только перечислить элементы и всё.
Но пользователи кода - долбоёбы, которые если не упадут на ObjectDisposedException, то материализуют этот IEnumerable в сто запросов в БД. Поэтому делается намеренно не по умному а так, чтобы никто себе жопу не прострелил. Чтобы не писали на каждой строчке .ToList() .ToList() .ToList() .ToList() .ToList().
А еще лучше возвращать 42. Никто ToList делать не будет..
Я хуй знает что у вас за проблема. Возвращаю/принимаю везде IReadOnlyCollection и не ебу себе мозг.
Почему не IReadOnlyList? IReadOnlyCollection не позволяет людям использовать for
>каверзных вопросов
Реал вопрос на собес от знакомого тимлида (когда еще можно было такое спрашивать).
Несколько мужчин (пусть будет 5) нетрадиционной ориентации сообразили парвовозик. Вопрос кто из них будет получать больше всего удовольствия и почему.
>использовать for
практически не пользуюсь им. Есть foreach, есть linq их хватает. А там где он нужен это либо кака-нибудь алгоритмика, либо конкретно работа с массивами и там все эти IList и IReadOnlyList нахуй не нужны.
Задача - сделать первые два элемента бесплатными, остальные платными. Как ты ее решишь? Можно конечно накостылить форычем с доп. переменной, но это неудобно
А должен принимать List, а возвращать object
>первые два элемента
Take(2) делаешь и меняешь их.
Но вообще, я хуй знает, но в тех проектах где я работаю, порядок элементов гарантирован только при отправке на фронт. В бэке везде если тебе нужны какие-то элементы, то у тебя есть условие какие именно, ты по нему фильтруешь и уже работаешь с тем что выпало. Поэтому в for и доступе по индексу смысла и нет.
Сейчас вот литерали глянул один из проектов. На 1500 классов всего 5 раз используется for. Из них только 2 связано с коллекциями. И то, там просто долбоеб делавший это, не догадался, что с помощью foreach, результат будет абсолютно тот же самый. Х.з. как это кодревью проскочило.
Прально! Только ВинФормы, только хардкор!
>А это для языка фича уровня 5 лет утверждать синтаксис.
Не так страшен чёрт как его малютка. Можно сделать всё если захотеть.
>>430286
>И что это означает?
Означает то что элементы массива изменить нельзя.
>int [] { 1, 2, 3, }
И что ты высрал?
>>428065
И кстати тоже не работает
ОшибкаCS1525Недопустимый термин "[" в выражении
>>430345
Да похоже они вообще никак не работают.
>Означает то что элементы массива изменить нельзя
Ты наркоман что ли? Такого поведения ни в одном языке нет.
Ты возможно не вкурсе про наличие immutable в шарпе или frozenset, но это же снова таки не то что твой ШУЕ мозг родил.
Я тебе серьёзно советую почитать какие-то книги типо Кормена или Таненбаума чтобы перестать нести какую-то хуйню про массивы что не дают менять свои элементы. Напиши свою реализацию такого сахара и предложи на заливку в репу, dotNET это опенсорс ты можешь предложить любые новые фичи.
> Ты наркоман что ли? Такого поведения ни в одном языке нет.
В плюсах это именно так и работает
>Такого поведения ни в одном языке нет.
На вот, в крестах попробуй скомпиль
const int AAA[3] = {1, 2, 3};
>Напиши свою реализацию такого сахара
Сахар он на то и сахар, что строится на базе уже существующего синтаксиса. А тут существующим синтаксисом не обойдёшься, тут компилятор допиливать надо.
>В плюсах это именно так и работает
Объявляешь массив константой, а через 20 строк присваиваешь по индексу значения.
В каком-нибудь случайном участке памяти.
Плюсы 2025
Вот чтобы всё было по канону: месиво из CQRS внутри CQRS, но без CQRS, динамические прокси, один интерфейс на всех. Запретить IDisposable и CancellationToken за место него вхуярить лайвтаймы, а работу осуществлять ровно в три потока.
Чтобы вы добавили?
Да ты петух просто, я же говорил
объявляешь массив и просишь всех "не пишите в него". А потом через год или где то в него запишут.
шарп 2025 и любых других годов во веки веков.
>>431114
>Запретить IDisposable и CancellationToken за место него вхуярить лайвтаймы
долбоеба трололо видно сразу. Видно по тому, что он нихрена в вопросе не разбирается.
так что можно добавить...ну книжку почитайте что ли, может умнее станете.
Но это не точно

>объявляешь массив и просишь всех "не пишите в него". А потом через год или где то в него запишут.
>
>шарп 2025 и любых других годов во веки веков.
А потом вспоминаешь, что в 2к25 массивы как таковые нахуй никому не нужны и успокаиваешься.
>что в 2к25 массивы как таковые нахуй никому не нужны
крудошлепам может и не нужны. Но не будем слушать их мнение про язык в котором активно продвигают Span-ы как раз в этих самых годах )))
Ещё не факт, что взяли. Я вот тоже на одном собесе хорошо себя показал, а в итоге меня не взяли. А другой, который думал, что завалил, сказали, что всё хорошо и дали оффер.
>долбоеба трололо видно сразу. Видно по тому, что он нихрена в вопросе не разбирается.
триггернулся, убогий ты петушара.
Какие подводные?
>крудошлепам может и не нужны
Ну давай, расскажи нам какой охуенно полезной и важной деятельностью занимаешься ты, что 'крудошлепы' тебе и в подметки не годятся.
Удачи. Мы рады за тебя.
Это местный шизик, я подписался на его долбоёбские высеры, он тупой очень, не понимает даже, как IDisposable работает. Скорее всего продуктовый код он не писал никогда
а ты забавный. тупой, но забавный. но тупой )))
>>431613
не крудошлепством и поэтому Span мне очень нужны. Иногда даже Unsafe (класс который. на чистый unsafe зачем опускаться - тут у нас не си)
>>431620
еще один про IDisposable будет учить. Тогда выходит и Jetbrains не понимают как работает и никогда продуктовый код не писали.
Логично же.
диссонанса не возникает? нет? ну ок.
Ну я вот везде массивы ебашу если не нужно добавлять или убавлять элементы. Просто привычка.
> Тогда выходит и Jetbrains не понимают как работает и никогда продуктовый код не писали.
Да, там долбоёбы одни, которые гоголем друг перед другом ходят
>Да, там долбоёбы одни
и то верно. прямо как в мс тоже долбоебы. потому что они говорят о проблемах диспозабле паттерна. вот даже местный крудошлеп говорит что "нет там никаких проблем у паттерна". а мс почему то проблемы видит.
вывод - мс тупые, а местный крудошлеп дартаньян )
логично же? ну логично? ))))
>не крудошлепством и поэтому Span мне очень нужны.
Ну так а конкретно чем занимаешься? Или опасаешься говорить, потому что понимаешь, что то, что ты делаешь по сути те же яйца, только сбоку.
петухан, у тебя все сообщения по одной копирке.
"ряяя, у меня не работает, потому что всё плохое"
"ряя, а вот в майкрософте не дураки, они же сами говорят, что оно всё плохое
>у меня не работает
я не говорил что не работает. я говорю "решение обладает недостатками или вообще никак не покрывает задачи".
это кое кто читает ЖОПОЙ и выдает СВОИ ЖОПНЫЕ мысли за чужие слова
>не дураки
что же ты пишешь на языке, который придуман дураками
лол, и ведь нет диссонанса у вас
>я не говорил что не работает. я говорю
со стороны виднее. Ты не понял примерно нихуя, и пытаешься что-то доказать.
Иди на хуй, короче, петух ебаный
со стороны крудошлепа? так себе оценка
а насчет доказать...
я просто высказываю аргументы
но если мой оппонент дебил и аргументация у него уровня "гыгы лол хаха", то это его не красит, а не меня унижает
а кому надо, те поймут и узнают что то новое
нас читают не только дегенераты
>со стороны крудошлепа? так себе оценка
Ну так ты точно такой же крудошлеп, только с необоснованной претензией на элитарность.
Правда глаза колет?
>Иногда даже Unsafe (класс который. на чистый unsafe зачем опускаться - тут у нас не си)
ptr[index] - для сишников-пидоров
Unsafe.Add(ref ptr, index) - для шарпо-бояр
Я правильно понял?
>Ну так ты точно такой же крудошлеп
не соглашусь. мне не нужен ни EF (до сих пор не знаю его и знать не нужно), ни всякие базы данных. Как вот jetbrains в своем решарпере не использует ни EF ни postgre, а вот многопотока и low latency там через край.
>Находишь такой самую последнюю книгу по сишарпу
нафига читать книги. любого курса фришного типа метаинита по диагонали, немного ютубов (их может ии прочитать вместо тебя) и далее у тебя в голове общий индекс "что вообще есть" и просто пишешь.
Если первый язык, то тяжелее, да. Но если не первый, то уже на второй день можно писать что надо.
>>432519
>Я правильно понял?
абсолютли. на шарпе же пишем, а не богомерзком си. Посмотри кишки методов дотнета и либ - вовсю используется именно Unsafe.(ref ...) и прочее. А * это для фанатиков.
>И за каким хером бы они в плагине для IDE сдались?
ни за каким. просто очевидно что у тебя мир за пределами крудошлепства не существует, ну или там все идиоты, которые "не понимают"
>Да похуй соглашаешься ты или нет
Собственно, как и мне. Это двач, тут никто нимому ничего не обязан (впрочем, как и в остальном интернете).
>'крудошлепом'.
здорово. теперь я смогу писать что знают EF и активно работал с бд (что конечно же нет)
Ну на этом и порешили.
>ни за каким. просто очевидно что у тебя мир за пределами крудошлепства не существует, ну или там все идиоты, которые "не понимают"
Нет в данном случае идиот тут только ты, т.к. не способен даже адекватно следить за нитью разговора. Это ты выдал тейк, что джетбрейнс молодцы, т.к. не пользуются в решарпере EF и postgres. Это все равно, что если бы ты утверждал что "смотри какие птицы охуенные, они летают и им даже жабры и плавники не нужны".
Они не используют ef и постгрес не потому, что они плохие или это признак крудошлепства, а потому что они в принципе не нужны в этом плагине.
>>432610
>Ну на этом и порешили.
Окей, записываем тебя в обычныго скриптописателя эникейщика, который пыжится доказать (прежде всего самому себе), что его деятельность имеет хоть какое-то значение.
>мне не нужен ни EF (до сих пор не знаю его и знать не нужно)
ЕF не знаешь
События не понимаешь
Многопоточку не понял
IDisposable понял не правильно
> нафига читать книги
зато самомнения дохуя и знаешь как правильно
сам WPF изменился мало. Так что боль доставит сам язык. И сразу же им вопрос "а почему вы не переехали на свежий дотнет" задай. Не так уж много причин почему переехать не выйдет. Может они просто не хотят учить новое.
>что они плохие или это признак крудошлепства
плохими или тупыми называли их как раз ВЫ >>431645, а не я.
Я ж говорю как раз наборот, что они поумнее вас будут ибо собаку схомячили на сложных задачах.
>>432815
только EF не знаю. Я его учил, но в силу того, что "негде применить" просто забыл и не слежу что там нового
остальное ...вообще не буду спорить, ведь спорят аргументами.
Наши же с тобой споры похожи на
я такой "вот интегралы, вот логарифмы, рациональные числа, мнимые числа, синусы"
А мне в ответ "гы гы, ноль похож на бублик. бублики это вкусно"
ты уже показал свою "круть" в плане понимания вот этих вещей. Я лучше других ребят послушаю, менее "крутых". Они хоть понимают о чем говорят )))
>зато самомнения дохуя
Не нужно быть особо умным чтобы знать недостатки того или этого. Достаточно просто хотя бы почитать про них. Это не секрет КГБ.
А далее просто чуть чуть мозг включить.
>и знаешь как правильно
Как человек, который изучал более 10 языков и половину из них использует постоянно (хотя и не сильно хочет, потому что без использования в итоге просто забывается, кроме понимания парадигм, но легаси же и денежку платят), да, имею мнение про "как изучать эффективнее без лишних трат времени".
Все языки они ж как братья, за исключением с "абсолютно другая парадигма" или "своеобразные типа rust". Так что зная один язык УЖЕ понимаешь что именно тебе надо писать. Остается вопрос "как это переложить в код". И вот тут помогут ИИ, ведь ты знаешь ЧТО спрашивать.
Конечно они фантазируют много, но можно просто спросить другой ИИ (их валом фришных) и получить истину.
>>что они плохие или это признак крудошлепства
>плохими или тупыми называли их как раз ВЫ >>431645, а не я.
Второе "они" относилось к ef и postgres. Какое тебе нахуй программирование, если ты в понимание смысла обычной беседы не умеешь.
>>433126
>И вот тут помогут ИИ
Судя по тому как прыгает контекст в твоих фразах, ты и есть нейросетка, причем очень тупая.
>я такой "вот интегралы, вот логарифмы, рациональные числа, мнимые числа, синусы"
ты в луже блевотины мычишь, ссышься под себя
>Второе "они" относилось к ef и postgres
ну это ж ты как то связываешь еф и пострге с ними. я же делаю ровно наоборот.
ты же упорно пытаешься тянуть одеяло на себя "мол им не нужно потому что не нужно"
а я когда то говорил что им это нужно? хотя бы полсловом? или это ТВОЕ ПОНИМАНИЕ что я так говорил? ты перечитай что я писал и ПОДУМАЙ
>>433345
ну и отлично. конечно я чувствую сарказм, но у тебя вообще плохо с детектом сарказма и абстракций "на котиках поясняю"
>>433346
бла бла. как и все остальное
СВОИ мысли и СВОИ слова выдаешь за мои
ничего не меняется.
и эти люди запрещают мне ковыряться в носу
Вернее это один человек, не умеющий в логику и аргументацию. Поэтому и выдает свое за чужое.
Впрочем, как то поплевать.
И ещё один вопрос. Какие самые популяные направления на дотнете? Что учить в первую очередь? Видел mvc, razor, blazor и проосто рест апи
Очень много отличий, это скорее разные платформы и языки, чем разные версии.
Аргументы типа "ты не научился правильно есть говно" как то не работают на меня. Наверное потому...что я вообще не хочу есть говно. И даже если мне дадут золотую ложку и пройду курсы мастерства по поеданию говна - говно все равно останется говном.
События в шарпе - ну реализация одна из многих. Тут вопрос в том с какой стороны стола ты сидишь. Кому то плюс "могу для отписки НЕ хранить ничего, а просто передать делегат и оно отпишет и мне это удобно делать, например, в Dispose". А кому то (мне) это минус ведь нахрена мне вообще писать метод диспоз, когда есть более удобные и надежные решения.
Про многопоток - тут события шарпа в пролете. Есть несколько решений, но ни одно из них не покрывает все проблемы. То есть это выбор из стульев, стульев с говном (которое просто размазано где то на спинке, а ведь можно просто не облокачиваться ))) и так и сидеть)
Но я, пожалуй, лучше возьму нормальный стул, а не буду "разбираться" как мне правильно сидеть на стуле с говном.
И так везде. А кто против - ну видимо они говноеды. Они даже гордятся тем, что научились есть говно и не пачкать свитер.
Ну...пусть гордятся, завидовать им не буду
>>433511
зависит от версий. в общих чертах майки решили переписать дотнет кросс и со шлюхами и "не будем тащить старое" - не стали тащить домаины, ремотинг, контракты, что там с дата связанное, запретили отрицательное зачатиеировать потоки и ... Не помню, давно было дело и зачем мне помнить то. Потом под действием общественности частично кое что портировали. А еще в фреймворке (не кор) спаны прикручены сбоку на самом деле.
Но в основном - писать на 4,8 это как писать на очень старом дотнете. Писать можно, но старье есть старье.
про диспоз и "не разобрался". ну там тоже просто
берем диспоз и начинается
нас могут вызвать дважды - добавим флаг disposed
нас могут не вызвать - подключим финализатор
возможный вызов из нескольких потоков - а мы Interlocked-ом
наследование - ну тоже что нибудь придумаем
нам передали диспозабле через конструктор - а пусть и передают bool leaveOpen как вон со стримами или HttpClient с его хендлерами ). Как это они не знают можно ли диспозить - а пусть знают.
в итоге - просто метод очистки превращается в огромную простыню костылей. И при этом все равно не решают проблему....барабанная дробь....когда просто забыли в диспоз отписаться от события..
Такая гора кода, а все равно получаем мемори лик.
И эту гору говна из костылей мне говорят "это намного лучше чем решение где нет этих недостатков, отписаться забыть нельзя, а диспоз метод не только мал, а вообще не существуют. Ты просто не разобрался"
сириусли? А "разобрался" это научиться писать эту гору говна (которая все равно не решает всех проблем) и потом все равно получить лик из-за забытой отписки?
Ну может кому то и нравится сидеть на этом стуле. мастерски сидеть. знать каждый его винтик и член торчащий. и мастерски маневрироваь жопой чтобы члены только частично втыкались (мастер ведь разобрался как это делать)
Но я все же выберу другой стул
>И ещё один вопрос. Какие самые популяные направления на дотнете?
монолитный бек наполовину распиленный на микросервисы
>нас могут не вызвать - подключим финализатор
не надо до такого доводить, просто в финализатор добавь какой-нибудь репорт о том, что объект не уничтожен, а потом почини по месту
>нам передали диспозабле через конструктор - а пусть и передают
тут всё просто: кто объект создал, тот его и уничтожает. Подключи IDisposableAnalyzers
> нас могут вызвать дважды
тут два пути, твой путь скорее распиздяйский. Я склоняюсь к тому, чтобы один раз создать и ровно один раз уничтожить
> в итоге - просто метод очистки превращается в огромную простыню костылей
я же говорю, ты не понял просто как это работает
> Такая гора кода, а все равно получаем мемори лик.
или ещё более страшная гора кода, с упоротым стектрейсом, которую вдобавок невозможно отладить поверх стандартной модели.
Чел, ты понимаешь, что если ты неправильно понял диспозабл и события - тебе никакое говно от джет брейнса не поможет? Ты хоть три умные библиотеки подключи, но руки они тебе не выпрямят
> запретили отрицательное зачатиеировать потоки
Лол. А что за доисторический форс засел в вордфильтре?
Что противоположно зaчатию? Правильно, aбopт. А засел этот форс по желанию левой пятки макаки.
"/api/zalupa"
"api/zalupa"
вызывает разное поведение?
Первый удалит весь адресс хоста до базового, второй просто конкатинируется.
"http://pupa.com/lupa/"
"http://pupa.com/api/zalupa"
"http://pupa.com/lupa/api/zalupa"
Это в мелких фирмах так, а вот в Газпроме завернули тех подрядчиков, у кого не сертифицированное ПО, они просто не прошли их проверки.
Это всё равно что знать, чем абсолютные пути к файлам отличаются от относительных.

В астра линукс, например, sdk и рантайм дотнета вплоть до 8 версии считай из коробки, а так вообще хоть даже 9-й ставь: https://docs.astralinux.ru/latest/start/netcore/
https://wiki.astralinux.ru/kb/net-core-191108093.html
В реестре что-то дотнетовое тоже очевидно есть:
https://reestr.digital.gov.ru/search/?q=.net (запрос так себе, и я только первую страничку посмотрел, но очевидно c# там использовали, хотя и не знаю насколько).
Еще вот этих ребят вспомнил, на авалонии сделали свою "импортозамещенную" скаду, в реестре есть: https://reestr.digital.gov.ru/reestr/1613356/?sphrase_id=3205910
Т.е. что помешает мне выпустить, например, asp net core приложение, попасть в реестр и крутить его на сертифицированном линухе - то, что Kestrel не в реестре российского ПО? Genuine question, сам в этой теме особо не разбирался еще.
>>433881
Частично сталкивался с таким. Если область для производства критически важная и быстренько с винды на линух, например, не перескочить (допустим, на заводе все OPC сервера на DA стандарте были сделаны), то никто сильно не горюет по этому поводу, оставляют эту часть на виндоус-серверах.
>что объект не уничтожен, а потом почини по месту
Это так не работает. Объект, а значит и диспоз может быть не твой. Кстати, Task реализует IDisposable. Часто вызывал у таска диспоз? Риторический вопрос.
>кто объект создал, тот его и уничтожает
Но зависимости могут иметь разное время жизни. И нужно где то трекать время жизни каждого объекта. А IDisposable никак не отвечает на вопрос трекинга. Он просто метод. А значит должен быть дополнительный код - ручной или унифицированный для трекинга и уничтожения (причем в обратном порядке от рождения)
и поэтому....
>твой путь скорее распиздяйский.
мой путь - перевесить эти проблемы на лайфтаймы, которые и являются тем дополнением, которое и трекать будет и терминировать. Ну ты будешь писать тут ручной код для каждого случая. А если родишь унифицированное решение - а чем твое отличается от тех же лайфтаймов?
>или ещё более страшная гора кода, с упоротым стектрейсом
НОЛЬ строк кода это никак не "более страшная гора". Стектрейс тут вообще не причем. Откуда ему быть то? причем тут исключения вообще. IDisposable НЕ ДОЛЖЕН вызывать исключение (CA1065)
>ты неправильно понял диспозабл
его я как раз понял правильно - он всего лишь метод. И НИЧЕГО БОЛЕЕ. А значит все вопросы на тему "а как и когда его вызывать, да чтобы не забыть, да и не дважды, да и не в разных потоках, да и в обратном порядке" он НЕ отвечает. А за это отвечает СТОРОННИЙ код. (ну или частично лапша внутри диспоз, но там просто защита от дурака, а не именно рабочий код)
То есть мы приходим к выводу - сторонний код инфраструктуры БУДЕТ. Вопрос лишь в том, какой он будет и что будет уметь. Ты предлагаешь велосипедить.
Причем велосипед будет убогий ибо без концепции токенов не может защитить от "забыли". И финализатор не поможет - Dispose ты вызвал, а мемори лик останется. Если можно забыть - это говно решение.
Для всяких там асп.нетов в принципе норм, а вот там, где время жизни не имеет четких границ - хрен. WPF отлично это доказал НЕ решив этот вопрос аж никак, а переложив все на weak диспозы.
А ведь можно взять готовое решение, которое делает то же самое и ЛУЧШЕ. Лучше оно тем, что помимо трекинга, который ты САМ пишешь каждый раз), позволяет не писать диспозабле, терминироваться вовремя (а не абы когда), позволяет НЕ забыть (это просто невозможно) отписаться, диспозит в обратном порядке, дает возможность защититься от диспоза если щас немного к месту это и так далее.
Концепция fail-fast. Просто не скомпилируется. Это важная концепция. Вон даже null safety притащили потому что лучше отловить на этапе компиляции, а не потом в рантайме какие то логи финализаторов читать (которых не будет)
> и события
понимание событий не делает их хорошими. А как раз наоборот.
твое "понимать" - значит сидеть на стуле с говном
Вся твоя аргументация сводится к "оно же в языке и ты его критикуешь и говоришь что есть варианты лучше - значит ты просто не разобрался"
Но BeginXXX тоже в языке. Почему же ты его забросил в угоду TPL, а тот (в большей части) в угоду async?
НЕ РАЗОБРАЛСЯ ЧТО ЛИ?
>что объект не уничтожен, а потом почини по месту
Это так не работает. Объект, а значит и диспоз может быть не твой. Кстати, Task реализует IDisposable. Часто вызывал у таска диспоз? Риторический вопрос.
>кто объект создал, тот его и уничтожает
Но зависимости могут иметь разное время жизни. И нужно где то трекать время жизни каждого объекта. А IDisposable никак не отвечает на вопрос трекинга. Он просто метод. А значит должен быть дополнительный код - ручной или унифицированный для трекинга и уничтожения (причем в обратном порядке от рождения)
и поэтому....
>твой путь скорее распиздяйский.
мой путь - перевесить эти проблемы на лайфтаймы, которые и являются тем дополнением, которое и трекать будет и терминировать. Ну ты будешь писать тут ручной код для каждого случая. А если родишь унифицированное решение - а чем твое отличается от тех же лайфтаймов?
>или ещё более страшная гора кода, с упоротым стектрейсом
НОЛЬ строк кода это никак не "более страшная гора". Стектрейс тут вообще не причем. Откуда ему быть то? причем тут исключения вообще. IDisposable НЕ ДОЛЖЕН вызывать исключение (CA1065)
>ты неправильно понял диспозабл
его я как раз понял правильно - он всего лишь метод. И НИЧЕГО БОЛЕЕ. А значит все вопросы на тему "а как и когда его вызывать, да чтобы не забыть, да и не дважды, да и не в разных потоках, да и в обратном порядке" он НЕ отвечает. А за это отвечает СТОРОННИЙ код. (ну или частично лапша внутри диспоз, но там просто защита от дурака, а не именно рабочий код)
То есть мы приходим к выводу - сторонний код инфраструктуры БУДЕТ. Вопрос лишь в том, какой он будет и что будет уметь. Ты предлагаешь велосипедить.
Причем велосипед будет убогий ибо без концепции токенов не может защитить от "забыли". И финализатор не поможет - Dispose ты вызвал, а мемори лик останется. Если можно забыть - это говно решение.
Для всяких там асп.нетов в принципе норм, а вот там, где время жизни не имеет четких границ - хрен. WPF отлично это доказал НЕ решив этот вопрос аж никак, а переложив все на weak диспозы.
А ведь можно взять готовое решение, которое делает то же самое и ЛУЧШЕ. Лучше оно тем, что помимо трекинга, который ты САМ пишешь каждый раз), позволяет не писать диспозабле, терминироваться вовремя (а не абы когда), позволяет НЕ забыть (это просто невозможно) отписаться, диспозит в обратном порядке, дает возможность защититься от диспоза если щас немного к месту это и так далее.
Концепция fail-fast. Просто не скомпилируется. Это важная концепция. Вон даже null safety притащили потому что лучше отловить на этапе компиляции, а не потом в рантайме какие то логи финализаторов читать (которых не будет)
> и события
понимание событий не делает их хорошими. А как раз наоборот.
твое "понимать" - значит сидеть на стуле с говном
Вся твоя аргументация сводится к "оно же в языке и ты его критикуешь и говоришь что есть варианты лучше - значит ты просто не разобрался"
Но BeginXXX тоже в языке. Почему же ты его забросил в угоду TPL, а тот (в большей части) в угоду async?
НЕ РАЗОБРАЛСЯ ЧТО ЛИ?

>мой путь - перевесить эти проблемы на лайфтаймы
и нихуя не поменяется, за место диспозов будешь лайвтаймы закрывать, только стектрейсы будут упоротые, а отладка - ад.
>за место диспозов будешь лайвтаймы закрывать
именно так. вместо разбора "эээ кто у нас тут должен помереть" я терминирую лайфтайм, и все связанные с ним умрут, да умрут правильно.
А в 99% терминировать будет инфраструктура, а не я.
Странно (а может и нет) что концепцию CancellationToken(и самостоятельную завязку на него всех кто должен прерваться при отмене токена) ты воспринимаешь нормально. А ТАКУЮ ЖЕ концепцию в плане "отрицательного продолжения жизни" ты
"не не не - тут все руками по старинке. Вот дергали же раньше метод Cancel() до прихода CancellationToken и ничего, как то жили, а ведь метод Dispose он такой же. Не пущу лайфтаймы проклятущие"
>только стектрейсы будут упоротые, а отладка - ад
в УПОР НЕ ПОНИМАЮ где ты там увидел стектрейсы то. Вот в асп.нет коре после запроса контейнер диспозит все что наплодил для запроса - какие стектрейсы и проблемы отладки это у тебя вызывает? А ведь он делает абсолютно ТО ЖЕ САМОЕ - добавляет рожденный IDisposble в scope и потом терминирует этот скоуп. Тут не просто похоже - тут АБСОЛЮТНО идентично.
>Коллеги тебя отхуярят скорее всего
ну разве что такие, как ты. но таких у нас просто не будет. потому что аргумент "ты не разобрался" не работает против аргументации "вот тут такие недостатки".
Я полностью понимаю, о чём ты говоришь. Но, к сожалению, ты просто не разобрался как с объектами работать
ок. побуду идиотом как жетбраинсы, майки и прочие которые видят в диспозе кучу говна.
А ты будь элитным говноедом, ведь ты мастер в его поедании
За сим и закончим наш "спор"
>побуду идиотом как жетбраинсы, майки и прочие которые видят в диспозе кучу говна.
Да кто блять видит шизофреник ебанутый. Их видят только долбоебы которые ещё не видели деструкторы в С++ и не писали их. Вот это вообще збс, тебе надо РУКАМИ вызывать освобождение объектов и оно при этом может завершится криво и тебе нужно писать логику на обработку такой хуйни.
Держу в курсе. Дали оффер на 180к сейчас сижу на 130к. Единственное смущает необходимость медосмотра. Несколько лет назад лечился от серьезной пиздецомы (рак щитовидки), как бы это не стало поводом для отказа.
>и оно при этом может завершится криво
ну если у вас диспоз методы могут выдать ошибку - всё с вами ясно. Как бы тут не о чем больше говорить. В моем мире диспоз не может выдать исключение потому что НЕ ДОЛЖЕН.
Ведь я пишу на шарпе, а в нем
https://learn.microsoft.com/ru-ru/dotnet/fundamentals/code-analysis/quality-rules/ca1065
"Метод System.IDisposable.Dispose не должен вызывать исключение. Dispose часто вызывается как часть логики очистки в предложении finally . Таким образом, явным образом создается исключение из Dispose принудительного добавления пользователем обработки исключений finally в предложение."
Если у тебя что то там КРИВО (ну как твоя голова и руки), и что то может очищаться с ошибкой - то и ОБРАБАТЫВАЙ ЭТО ВНУТРИ СВОЕГО ДИСПОЗЕ. Выше диспоза оно проползать не должно по природе. Можешь в лог писать, можешь в консоль, можешь в спортлото - но не кидать исключение из диспоз.
А потому проблемы "тут диспоз исключение кинул" просто не существует в нормальном мире. А в твоем шизофреническом видимо существует. Ну там что угодно может существовать, ведь вам норм.
>>434412
>Единственное смущает необходимость медосмотра
то есть необходимость вкалывать и писать код не смущает?
Сколько лет попыта?
>Не должно, т.к. незаконно. Единственное, с чем тебя могут прокатить - это ДМС, но тут уж увы.
Может его полярником программистом отправят. Или на атомную подлодку, интегрировать медиатр
нет. таки про диспоз. про кресты и деструкторы он только в этом посты, а остальные посты он говорил про диспоз и как лайфтаймы усложнят какие то мифические стектрейсы.
>лайфтаймы
Что за лайфтаймы? Ты растбук прочитал и у тебя синдром долбоёба, которому фич из других языков не хватает?
>Что за лайфтаймы?
зис. достаточно посмотреть несколько минут. он пояснит
https://youtu.be/Sq_h5bVWJ0k?t=500
>растбук прочитал
вообще то да, прочитал. но все же это совсем другие лайфтаймы
и то верно. пиши бойлерплейт. ведь он тоже не решает нихрена, но лишний код.
(странно что эти люди перестали использовать BackgroundWorker с его Cancel и пересели на CancellationToken. Хотя...они просто макаки из мира программирования и повторяют не понимая)
я ж не настаиваю на своем. я настаиваю на кротах.
Как думаешь, почему ты все вокруг тебя макаки и крудошлёпы, а ты один умный?
Это риторический вопрос, можешь не отвечать
>Как думаешь, почему ты все вокруг тебя макаки и крудошлёпы, а ты один умный?
потому что не хотят развиваться. очевидно же. считают себя уже супер специалистами и отрицают все новое.
вопрос был бы риторическим если бы оппоненты не отрицали критику херней типа "мне норм, а ты не понял"
и им насрать кто критикует, даже если сами майки.
латентные жависты, вот и весь ответ. Ну или любители пожрать говна.
> все новое.
какое новое? этому говну чуть ли не 10 лет, его под райдер наговнокодили Иванов и еще долбоёб один. Они пропихнули эту хуету под видом решения какой-то особо таинственной проблемы, которую только посвящённые могли понять
Потом мы сами просто перестали пользоваться этой библиотекой, потому что оказалось, что проблемы не было никакой.
А ты как попка-дурачёк, 10 языков выучил как так оказалось, что среди них нет SQL?, а мозгов не прибавилось
>какое новое? этому говну чуть ли не 10 лет
и что? все равно новее подхода "бойлерплейтим в диспозабле и надеемся что нас не забудут вызвать и мы ничего не забудем, а проблемы вызова пусть каждый лисапедит сам"
>которую только посвящённые могли понять
гм. то есть человек который пишет бойлерплейт для диспозе он долбоеб или посвященный? потому что он как бы понимает зачем он это пишет и КАКУЮ ПРОБЛЕМУ решает этим кодом.
Так что он или долбоеб, который не понимает зачем он это пишет. Или посвященный.
Ты из каких?
>Потом мы сами просто перестали пользоваться этой библиотекой, потому что оказалось, что проблемы не было никакой.
вопрос "ты из каких" снят )
>как так оказалось, что среди них нет SQL?
с чего ты взял что я не знаю SQL? Я смотрю, тут у людей с логикой вообще ТУГО
Если я не использую EF, то я не знаю SQL? Обычно наоборот говорят, что "юзаешь ORM и SQL не знаешь"
Л - логика от анона
Но да, я его в эту десятку не записываю, поскольку это сопутствующая технология.

>и что?
то, что ты, используешь мусорную библиотеку, которой кроме тебя никто не пользуется, и делаешь код несовместимым со стандартами разработки.
Ты эгоистично пишешь только под себя, и забил хуй на то, что проект, на котором ты насрал придётся поддерживать разрабам, которые будут тебя материть за глаза и пытаться понять, наркоман ли ты или просто долбоёб.
Ты создаёшь лишний слой непонимания и сомнений, ты как ёбаный рак, гниль, которая привязывает код к себе. Без обид, но ты мудак. В конце концов, тебе объяснят как маленькому дурачку, как айдиспозабл работает, но скорее всего будешь уже срать на другом проекте.
У нас был такой долбоёб. Он написал PrivateCancellationToken. Два года переписывали код на это говно, два года объясняли человеку, что он изобрёл CancellationTokenSource.
Вот и ты такой же долбоёб, вбил себе что-то в голову, не разобрался нихуя и других лечишь
>несовместимым со стандартами разработки.
что за стандарты такие? слово то какое СТАНДАРТЫ. можно эти СТАНДАРТЫ в студию?
>на котором ты насрал придётся поддерживать разрабам
ну было бы насрано кастомное решение, какая разница?
взять MVVM Community Toolkit. Там типичное от WPF weak решение мессенджера. Но есть и стронг, для которого придется рожать какое то решение что не было ликов. Выходит, создатели этого фреймворка нарушают стандарты MVVM фреймворков для WPF? Или просто нет никаких стандартов, а есть набор решений "ну более менее работают в данной ситуации" )
>ак айдиспозабл работает
как он работает - поясняет каждая первая статья в инете. но как с этим работать - тут статьи делают пук среньк и "ну вы там как то сами ага". То есть банальное "ну вы там вызывать не забывайте, а как...а мы не знаем же вашего проекта". Вот такие вот СТАНДАРТЫ
>Два года переписывали код на это говно
то есть до этого человека у вас была неведомая хуета вместо токенов отмены? видимо миллион методов Cancel, иначе что там 2 года переписывать то?
>два года объясняли человеку, что он изобрёл CancellationTokenSource.
Который вы все равно не использовали и человек вам научил хоть чему то. Просто взял свою реализацию вместо "искаропки". Но суть та же
Ну может за 2 года до вас дойдет, что лайфтаймы это такие же токены отмены (у них код совпадает в простой реализации на 100% только названия другие), только в другой семантике. А может и не дойдет. Тупенькие же вы. Если бы не мс (в вашем случае один молодец), так бы вы и юзали методы Cancel во веки веков.
Беда в том, что мс далеко не всегда вносит нужное в фремворк. Вот Async*ResentEvent и другие асинки есть в отдельной либе Microsoft.VisualStudio.Threading (зацените название то), но уже скоро дотнет 10, а таких классов нет во фреймворке, видать асинк пишут 3.5 человека в мире.
Task реализует IDisposable
Готов дать руку на отсечение, что у тебя в проекте везде вызывается Dispose для тасков?
Или ты не умеешь работать с диспозами? )))
>>Он написал PrivateCancellationToken.
>Писал что?
Чел написал класс, PrivateCancellationToken, который по сути собой представлял собой CancellationTokenSource
>то есть до этого человека у вас была неведомая хуета вместо токенов отмены
Нет, у нас были обычные токены, но чел не понял, как с ними работать, написал своё говно. Мы пиздец, кринж словили, но два года переписывали обычный код на эту хуету, чтобы не расстраивать большого властного начаальника
>Готов дать руку на отсечение, что у тебя в проекте везде вызывается Dispose для тасков?
>Или ты не умеешь работать с диспозами? )))
Эээ. Дядя, ты дурак?
>два года переписывали
два года чтобы заменить одно решение на идентичное? Которое джун бы за пару вечеров осилил.
у вас там какие то реально консервированные деды сидят.
Не там вы ловите кринж не там. Кринж нужно ловить когда HttpClient кидает TaskCancelledException вместо таймаута (да и вообще принципиально хреново работает с таймаутами). А теперь скажи что это НЕ СТАНДАРТ ), ведь это офф решение.
>Эээ. Дядя, ты дурак?
так стандарты же. Если класс реализует IDisposable значит у него нужно вызывать Dispose
это ж СТАНДАРТ )
Ээээмммм нуууу эээээ как бы. Зачем?
Я видел схожие вещи когда люди пишут свои версии классов из .NET или вообще свои реализации каких-то фич и библиотек готовых, но не понимаю зачем это делать.
Вероятно проблема в том что я считаю что люди которые пишут дотНЕТ явно поумнее меня и больше понимают, я читал исходники реально поумнее, да и банально там его в течение десятка лет писали и проектировали сотни человек которые уже выловили все возможные баги и проблемы и провели максимум оптимизации на спичках. Тоже самое какой-то Fluentvalidation который писала куча народу.
Обычно в коде таких выпердышей можно увидеть что автор тупо перепутал работу и петпроект. Они пробуют такое сделать чтобы разобраться как это под капотом работает или попробовать штуки из книг которые читали.
>я считаю что люди которые пишут дотНЕТ явно поумнее меня и больше понимают
это ты зря считаешь
1 не поумнее и поэтому творят дичь. Ну тут много чего я уже писал про это
2 есть спорные вещи, где у каждого варианта есть недостатки. Те же события, свойства
3 решение должно удовлетворять всех - в итоге оно просто базовое. Тот же DI от майков умеет только в самый базовый базис и не умеет даже в декораторы. Зато умеет в Keyed, что не по канону (но это уже к спорным вещам)
>3
Так это и есть смысл всей этой затеии с фреймворками. Это должен быть просто набор базовых кубиков, фреймворк который навязывает тебе какую-то реализацию это плохой фреймворк. Ещё хуже когда ты не можешь отказаться от того что он будет делать и вынужден костылями убирать логику.
> Тот же DI от майков умеет только в самый базовый базис и не умеет даже в декораторы.
И это замечательно. Всегда беру его.
> так стандарты же. Если класс реализует IDisposable значит у него нужно вызывать Dispose
Да, там не идеально, но если джун придёт, тебе не надо будет его учить расширенным практикам.
Лучше знать особенности поведения таски и httpclient, чем особенности поведения какой-то ноунейм библиотеки - на следующем проекте пригодится.
А использовать крутые индивидуальные решения - это круто до тех пор, пока проблемы не начнутся. Там ты ССЗБ, написал всё сам, тебе никто не поможет
>но если джун придёт, тебе не надо будет его учить
а я лучше научу. А тот этот джун мне накособочит с диспозами. Я лучше не дам ему возможности совершать ошибки. Компилятор в помощь как бы.
>расширенным практикам.
бедные джуны мира. как же они выучили CancellationToken-ы, просто уму непостижимо. Видать их отправляли на многолетние курсы где они 10 лет слушали наставления как использовать CancellationToken. По другому никак - слишком сложная технология.
>Лучше знать особенности поведения таски и httpclient
лучше когда таких особенностей просто нет. А пока что просто убрать розовые очки "раз от мс значит хорошо". Нет не значит.
>тебе никто не поможет
тут ты прав. ведь 10 лет ждать пока джун освоит технологию и с курсов вернется. придется эти 10 лет самому. То ли дело простая (на самом деле нет) и свежая (14+лет) технология https://learn.microsoft.com/en-us/previous-versions/dotnet/reactive-extensions/hh212123(v=vs.103) и не велосипед.
>лучше когда таких особенностей просто нет
Давай пример приведу. Чтобы не ебать мозги, я просто с проекта выкинул https://restsharp.dev/ , и заменил вызовы на http клиент.
> Reactive Extensions Class Library
их вроде даже в стандартном фреймворке нет
>я просто с проекта выкинул
ну выкинул и выкинул, а я вот никогда их и не брал. этих клиентов не один и у каждого свои преимущества и недостатки.
>их вроде даже в стандартном фреймворке нет
как и Community.Toolkit
как и Microsoft.VisualStudio.Threading
и что
хз в общем что ты хотел сказать. Потому что удобство это одно, а подводные грабли - совсем другое. У хттпклиента грабли с таймаутами, с проксями, с днс.
и если без удобств можно обойтись, то грабли бьют по лбу и приходится с этим что то делать.
> то грабли бьют по лбу и приходится с этим что то делать.
твои грабли растут у тебя из жопы.
Ты не смог разобраться с базовыми вещами и пытаешься чинить их с помощью дебильных библиотек, которые нихуя руки не выпрямляют, но делают только хуже.
у меня был один знакомый, звали Андреас Папагиоргиу. У него всё тормозило и он думал, что если он будет использовать автомаппер, то у него с какого-то хуя квери оптимизируются.
в итоге нихуя, разумееся, не оптимизировалось, он въебал говна вокруг этого автомаппера, завернул всё в CQRS (как он это называл), потому что думал, что CQRS ему всё оптимизирует.
Но он опять же не понял, что такое CQRS, и просто подключил за место DI MediarR.
Код начал напоминать либо серию вызовов автомаппера из медиатора, либо серию вызовов медиатора из автомаппера. Там события какие-то. Короче, чел вообще не врубился, что такое CQRS.
Вот и ты так же
"Если лежит говно и тебе не нравится как оно воняет - значит ты просто не разобрался как его правильно нюхать и есть"
технически, может логика эта и верна....но только для говноедов
А ведь именно эту логику ты и применяешь. Ты говноед?
где можно увидеть платность датагрида и расширения для IDE?
про ричтекстбокс не знаю их там не один
фикс багов платный? с поддержкой не путаешь?
> где можно увидеть платность датагрида и расширения для IDE?
https://github.com/AvaloniaUI/Avalonia.Controls.TreeDataGrid/issues/307
Про расширение можешь в телеге почитать. Текущая версия больше не будет обновляться, новая будет доступна только подписчикам avalonia accelerate
> про ричтекстбокс не знаю их там не один
Вообще-то там пока нет ни одного. Но тот, который будет, тоже только для подписчиков.
> фикс багов платный? с поддержкой не путаешь?
Именно фикс багов. Issue на гитхабе рассматривают только от тех, у кого платная поддержка. Остальные могут годами висеть

>[StructLayout(LayoutKind.Explicit, Pack = 1)]
А ещё такой каст это Undefined Behaviour (через Unsafe.As - тоже).
Пик: метод M() должен вернуть 15, а возвращает 1.
Просто вспомнил про вот этот вопрос: https://github.com/dotnet/runtime/discussions/96434
Хотел как-то сам проверить это, но чё-то не додумался тогда до кода.
Я короче хочу сделать приложение для андроид на c#, но меня волнует насколько дерьмовой будет работа с вызовами апи из андроид sdk из шарпа
Допустим я сделаю интерфейс на maui/avalonia/годот в конце концов, но насколько плохо будет взаимодействовать со всякими специфичными вызовами типа создания и удержания сервисов в пуш уведомлениях, всевозможных требованиях разрешений, микро, камера и прочее
Переход на Яву/Котлин/дарт/флаттер/другое мобильное наречие не рассматривается, по ряду причин
В целом у меня будет примерно такой функционал - сервис в пуше, держание открытого сетевого порта, который должен постоянно жить, флаг висящий в уведомлении, работа с storage access framework, ну и полный доступ к всем файлам internal storage.
Мимо гд пукальщик, решивший вкатиться в реальный мобайл, а не только игровой.
>Я короче хочу сделать приложение для андроид на c#
мимо 5 лет на ксамарине писал приложения.
> всякими специфичными вызовами типа создания и удержания сервисов в пуш уведомлениях, всевозможных требованиях разрешений, микро, камера и прочее
со стандартными вызовами всё хорошо будет. Просто будешь писать c# код, точно такой же как на джаве писал бы
> В целом у меня будет примерно такой функционал - сервис в пуше,
0 проблем
> держание открытого сетевого порта, который должен постоянно жить,
тут проблем не вижу, сетевое соединение 100% на стандартном дотнете будет написано (но есть сомнение, что оно вообще нужно, потому что даже нативный андроид будет пытаться фоновые процессы тушить)
> флаг висящий в уведомлении, работа с storage access framework, ну и полный доступ к всем файлам internal storage.
как будто стандартная фигня, ожидаю что нет проблем
Проблемы в dotnet-android только тогда начинаются, когда тебе нужно нативную JAVA библиотеку самому заворачивать в в c#. Это сложно, но нужно очень редко.
Всё остальное решается. Про производительность не думай, она достаточная, чтобы ты разницы не заметил.
>(но есть сомнение, что оно вообще нужно, потому что даже нативный андроид будет пытаться фоновые процессы тушить)
Тут без вариантов, нужен безсонный аптайм небольшого сетевого ресурса, висящего на порту, это залог успеха. Я пока почитал про foreground service, вроде бы то что надо.
>Проблемы в dotnet-android только тогда начинаются, когда тебе нужно нативную JAVA библиотеку самому заворачивать в в c#
Я так понял речь идёт про Java.Interop? У меня такого в целом не предвидится, я все намерен держать в с#, но на будущее интересно.
>Всё остальное решается. Про производительность не думай, она достаточная, чтобы ты разницы не заметил.
Насколько сильно бьёт по ядру с#, без учёта вызовов платформенного апи? У меня будет несколько высоконагруженных unsafe модулей, которые по хорошему должны бы иметь сопоставимую с плюсами производительность, как это происходит на Винде. По ним никакого удара на Андроиде не будет? Вроде бы и не должно быть, но мало ли.
>Тут без вариантов, нужен безсонный аптайм небольшого сетевого ресурса, висящего на порту, это залог успеха. Я пока почитал про foreground service, вроде бы то что надо.
это не помешает андроиду затушить твоё приложение. Ты думаешь, один такой умный?
Даже если заставить юзера отключить умный режим энергоэффективности для конкретного приложения? Как-то ж у меня работает вот эта штука без глушения, просто вися в фоне и в уведомлении
https://f-droid.org/packages/be.ppareit.swiftp_free
При чем работает даже находясь под другим юзером который в данный момент неактивен (у меня есть телефон с линейджем где несколько юзеров)
Если ты используешь телефон как сервер, что довольно странно, то ты можешь позволить себе просто уведомление повесить, и оно не даст андроиду пристрелить твоё приложение.
Если ты пишешь обычное приложение для пользователей - то они его просто выкинут сразу, потому что либо работать НЕ БУДЕТ, либо их заебёт уведомление в шторке.
Ну так а я о чем. Повешу foregroundservice которое делает несмахиваемое уведомление и по идее должно работать, просто чел сказал что сеть по какой-то причине все равно прибьет, не смотря на уведомление. Да и откуда уверенность что юзеров это напрягает? Их же медиаплееры не напрягают. Да и юзеров там обычно столько говнины из всевозможных помоек что мое уведомление даже не будет заметно) Впрочем у меня спецсофт для спецнужд, потому мою целевую аудиторию эта штука не должна смущать.
>Если ты используешь телефон как сервер
Видишь ли, если использовать мультиюзера в андроид 12+, то шарить файлы между юзерами можно только таким способом. Раньше, в 10 Андроиде я просто под рутом ходил в user11, user12 и т.д. и туда руками кидал и оттуда брал файлы, а вот начиная с 12 - юзерфайлы теперь живут в отдельном спейсе к которому даже под рутом доступа не получить. Вот и пришлось извращаться с ftp, который однако видели все юзеры и на который можно было кидать файлы.
>просто чел сказал что сеть по какой-то причине все равно прибьет, не смотря на уведомление.
не, никто не говорил такого.
> спецсофт для спецнужд, потому мою целевую аудиторию эта штука не должна смущать
Я думаю учитывая этот факт, тебе надо начать с автомаппера и медиатра. Все крутые пацаны используют эти две библиотеки так как уважают CQRS и DDD. И если ты пишешь код в обход автомаппера - ты долбоёб с обоссаным лицом. Подумай в эту сторону
Написано
>тут проблем не вижу, сетевое соединение 100% на стандартном дотнете будет написано (но есть сомнение, что оно вообще нужно, потому что даже нативный андроид будет пытаться фоновые процессы тушить)
>автомаппера
Передо мной ещё ни разу не возникало задачи для которой мне бы пришлось юзать эту либу, а сравнить массивы я и без нее могу. Мне пока хватает обычного сравнения типов, а ее функционал похож на автоматизированный способ скрещивания ужа с ежом без применения интерфейсов, либо в случаях когда их применение невозможно (например из-за уебищной изменчивой архитектуры приложения).
>медиатр
Возненавидел контейнеры ещё при знакомстве с zenject. Называется как наплодить вместо 1 проблемы 10. Лучше буду писать по дедовски на mvc, меньше геморроя будет и отладка проще.
Извини если задел ранимые чувства рантайм падающего гоя живущего едиными автотестами, я не специально
опять чатгпт мне пишет. позовите живого человека, желательно понимающего то, что он говорит.
У нищих слуг нет, сам позови
Пройди за меня тест Тьюринга, бро. Я хоть и не бот, но тест Тьюринга не могу пройти.
>ройди за меня тест Тьюринга, бро. Я хоть и не бот, но тест Тьюринга не могу пройти.
Ты просто не полный

Для создания объектов рекомендуется использовать современные DI контейнеры:
Managed Extensibility Framework (MEF), Castle Windsor или StructureMap.
Так же хорошей практикой считается использование комбинации библиотек Automapper и MediatR, что позволит добавить валидатор, что позволит написать вам ВАЛИДАТОР и не даст создать некорректный объект
Блять, забаньте уже этого долбоёба!
Нахуя ты упоминаешь протухшие и разложившиеся технологии и библиотеки?
>Нахуя ты упоминаешь протухшие и разложившиеся технологии и библиотеки?
Потому что весь дотнет код должен быть единообразным и переведён к хорошим практикам DDD, CQRS, чистой архитектуры и SOLID.
>Разве DDD не ломает к хуям SRP принцип из SOLID-а?
Да кто бы знал, что за поебень этот ваш DDD