>>3474933 В конфиге автомаппера приходится РУКАМИ писать методы-конвертеры. То есть кода с говёным автомаппером получается БОЛЬШЕ, чем без него. Впрочем, за это его и любят нубы: нахуярил конфигов и можно коммитить - вроде как не бездельничал.
По поводу new. Например, нужно читать большие файлы в десятки гигабайт и обрабатываться чанками. Вот так написал хейтер new:
while ... byte[] bytes = reader.ReadBytes(count);
После чего был обоссан, выебан ножкой от стула и выгнан на мороз с волчьим билетом. Если размер файла 16 Гб, а count = 16K, то получаем всего лишь миллион аллокаций массива. Зато new нет...
Единственная аллокация с new. Да, можно пойти ещё дальше, сделав буфер полем класса, статическим полем класса или, более того, заюзав пул, но это уже мелочи. Факт в том, что хейтеры new - имбецилы. И пока вы существуете, я ценюсь выше как специалист.
>>3475049 если это на разок считать данные скриптом - то и похуй. Главное, что ЗАПАХОВ кода нет. По хорошему, надо спрятать метод ReadBytes за автомаппером чтобы был достаточный уровень абстракции
Читал тред и поражался. Млять, неужели кто-то до сих пишет мапперы (конфиги мапперов) вручную? Установите в IDE расширение для маппинга и генерируйте код одним кликом мышки или нажатием шортката.
Я, если без шуток, в ахуе, откуда берётся столько маппинга у людей.
Видел на проектах вплоть до 6-7 слоёв. А всё потому что ебутся с медиатром, в котором нельзя методы вызывать по нормальному и все аргументы надо объектом передавать.
ПРосто выкидываешь медиатр, и автомаппер автоматически становится не нужен
>>3474978 То ли дело лобком генерировать гетсеты и не иметь ни одной нормальной комьюнити иде с коробочным спрингом... >подмелкомягком У дотнета лицензия то посвободней будет чем у наших дорогих друзей >платформозависимом Вылезай из криокамеры
>>3475062 Умение способный уникальное учен ик. Мы втроем шли по тропинке ноги топали по мягкой мокрой грязи издавая шлепающий звук Сегодня днем шел дождь и от него земля была грязной а ноги липкими Ботинки были порваны
>>3475056 >Установите в IDE расширение Какое? Вроде такой функции нет и там минимальная поддержка. А так да, бывают сложные мапперы и нужно как следует посидеть и тщательно написать код, а затем тесты на мапперы
>>3474778 (OP) Ну и нахуя перекатили? Чтоб ещё пару ебланов закатились и себе жизни поломали? На Линкедине половина вакансий создана чтоб обучать нейроHRов, четверть чтоб компании показывали свой рост перед инверсторами. Оставшаяся четверть ищют людей-оркестров с функционалом айтиотдела на зп в 2к баксов.
>>3475111 Потому что круговорот финтеха, где сидят одни и те же 50 летние жабисты/плюсисты этот круговорот начавшие. В геймдеве на позиции шарпистов нормально мест есть, про бугор ваще молчу.
>>3475115 В гейдеве традиционно низкие зп и ублюдочные мрази на менеджерах. Без исключений. За бугром дотнет умер. Из реальных вакансий либо знание какого-нибудь нахуй не нужного датского и ворк пермит с хождением в офис в Эйхуйнахуйховене, либо ебаный человек-оркестр в стартап за три копейки, чистить говна за паджитами.
Анон, подскажи. Вкатываюсь в ойти, выбрал c#. Посмотрел по требованиям в среднестатистической вакансии (пока что фронт), помимо самого с# нужно знать .net, asp.net и sql. Есть ли разница, в каком порядке их изучать, и есть ли вообще "программа минимум", чтобы хотя бы на стажировку залететь самоучке без бумажке? про необходимость накрутки стажа осведомлен
И дополнительный вопрос. У большей части просмотренных вакансий есть пункт "знание реакта - большой плюс", или что-то такое. Нахуя им нужно мое знание джавы, если вакансия для шарписта? Мне ее действительно нужно хотя бы до базового уровня довести будет, или можно забить на первых порах?
>>3475456 >>3475375 Т.е. ваш говномаппер в рантайме через рефлексию поля сетает, лол? Какое свойство, перодля? У вас нет проверки на этапе компиляции, что есть маппинг из сорса в таргет? Вы идиоты?)))))
>>3475515 >Т.е. ваш говномаппер в рантайме через рефлексию поля сетает, лол
В этом его главное приемущество. Благодаря позднему связыванию объекты не зависят друг от друга, а разработчик может не беспокоиться о том, какие свойства куда замаппятся.
Всё работает само и бесплатно, а тебе только остаётся зарегистрировать маппинг один раз при старте проекта.
>>3475528 >в рантайме через рефлексию >бесплатно >один раз при старте проекта хорошо, что вас, мерзких гандонов, не пускают на нормальные проекты. сидите дальше црмки пилите, уроды
>>3475505 >выбрал c#. Беги пока еще не поздно, свичься в джависты и живи нормально с освоеным спрингом, жрать везде найдешь (кроме геймдева, но там впринципе жрать нехуй) >Нахуя им нужно мое знание джавы, если вакансия для шарписта? Потому что ищут фуллстеков за 3 рубля и хотят натравить тебя на то что паджиты не доели, ибо недурные. По делу - забей на рекакт и просто освой js, он простой и тебе хватит, а все их местные фреймворки подтянешь там где возьмут. Максимум доку прогляни чтобы с умным видом что-то проквакать на собесе
>>3475577 >Беги пока еще не поздно, свичься в джависты Я бы в бэк хотел уйти, после того, как хотя бы минимально в профессии освоюсь. Красить кнопки как-то мех, учитывая, что я не дегенерат.
>По делу - забей на рекакт и просто освой js, он простой и тебе хватит, а все их местные фреймворки подтянешь там где возьмут. Хорошо, спасибо.
>>3475664 >А вот у джавистов ничего из перечисленного нет. Включая гетсеты которые они генерируют руками лобком
>А? Куда свободнее GPL? Ну например отсутствие требования на публикацию сырцов форка, уже сильно свободнее >Не говорите ему что львиная доля стдлиба только для шинды. Платформозависимый код заключается в следующем: Сокеты Треды и локи Файловая система Консоль и дескрипторы окон Импорт библиотек Все работает из коробки под всеми заявленными платформами кроме потоков на вебассембли, хз о чем речь.
>>3475700 > Включая гетсеты которые они генерируют руками лобком Так трясёт, потому что ИТТ свиньям не дали такого же и надо ручками натыкивать?
> требование не ограничивать выданные свободы Так куда свободнее GPL?
> Платформозависимый код заключается в следующем: > Сокеты > Треды и локи > Файловая система > Консоль и дескрипторы окон > Импорт библиотек > Все работает из коробки под всеми заявленными платформами кроме потоков на вебассембли, хз о чем речь. Что сказать-то хотел? Лишь бы высрать тебе что-ли?
>>3475711 >Так куда свободнее GPL? Ты жопой читаешь? Сравни степень разрешительности MIT (под которой дотнет) и GPL >Что сказать-то хотел? Лишь бы высрать тебе что-ли Да просто думал с человеком а не с дебилом разговариваю который не знает как обеспечивается кроссплатформа и какие ньюансы у нее, my bad
>>3475711 >Так трясёт, потому что ИТТ свиньям не дали такого же и надо ручками натыкивать? Та как будто это единственная проблема жабы. Она просто самая ощутимая после шарпов, к хорошему увы привыкаешь быстро. А вот условные деревья выражений, методы расширения и еще масса мелких но приятных фич, включая unsafe может и не пользуется большим спросом, но после вольностей шарпа такое ощущение будто сел писать на визуалбейсике который почему-то похож на шарп и даже если хочется порой чего-то эдакого то сразу думаешь что ну его впизду, и так сойдет и так будет работать
>>3475732 Зачем тебе деревья выражений? Чтобы что? Я сильно сомневаюсь, что ты занимаешься статическим анализом, с вероятностью 102% ты пукаешь джейсоном в автомапер.
>>3475729 >Сравни степень разрешительности MIT Сравниваю: GPL - код открыт MIT - спиздил и закрыл код Итого: GPL - степень разрешительности 100% MIT - степень разрешительности 0%
>>3475770 чтобы генерировать SQL запросы автомаппером, очевидно же.
И похуй, что так делают только долбоёбы, но в java коде такого ещё 10 лет не будет.
Зато есть Spring, уюбищный бесконечный монолит, где всё встроено и работает хуй знает как, и на изучение котороно необходимо тратить МЕСЯЦЫ. Даже всеми трижды отхуесошенного медиатра как отдельной библиотеки в спринге нет, надо колдовать с XML, аннотациями спринга и прочей хуйнёй.
Большинство актуальных java проектов сейчас работает на спринге 2-3 версий, с JAVA десяти-15 летней давности, потому что обновлять что-то нереально.
А там даже VAR нет
Кто сравнивает java с дотнетом - у него 78 IQ уровня хoxoл. Объективно java сейчас только на легаси проектах осталась
>>3475770 Чтобы писать рантайм генерацию кода и при этом быть в аот. Например, для своего очень быстрого бинарного сериализатора. Я ж говорю, фича популярностью не пользуется, но это не значит что ее никто не использует в тех же клонах автомаппера, которые имеют скорость х0.5 от нативного маппинга. А не было бы ее - осталась бы только генерация исходников перед компиляцией либо рефлексия с падением производительности в порядок.
>>3475812 Тем не менее, на джаве зарплаты выше, а работа будет и через 20 лет. На модном крутом сишарпе все вакансии - это чистка говна в аутстафе с хохлами за три копейки.
>>3475505 >Вкатываюсь в ойти, выбрал c#. Если любишь Россииюшку и планируешь в ней жить лучше уж 1с учить. Также профитно, а конкуренции меньше.
А если ты хочешь на западного барина работать то забей. Бешеная конкуренция с паджитами, которые за косарь бачей в очередь станановятся. По удаленке, 40$ это потолок для лидов. К тому времени когда ты до этого грейда доберешься через 10-15 лет код уже никто писать не будет. И умение писать код будет как умение паять схемы сейчас, т.е. прикольно, но нахуй никому не всралось. Готовые оттестированные модули будут писать нейронки, а другие нейросети, под присмотром паджита сеньера будут их как лего собирать, и вываливать в энтерпрайз.
Вообще не советую сейчас в любое кодописательство вкатываться. Это гиблое дело.
>>3475515 Там скорее всего рефлексия на этапе инициализации, и в её время динамически генерируется код самого маппинга. Судя по скорости рефлексия в тайнимаппер (сука, тайни наоборот должен быть самым быстрым). При этом маппинг никогда не является бутылочным горлышком, поэтому будь он даже в 10 раз медленнее, это было бы в рамках погрешности всего приложения. Мы не любим автомаппер за то, что то, что там происходит, слишком неявное. Тебе IDE может показывать, что какое-то свойство не используется, а на самом деле это не так. И из-за этого может быть просто невероятно сложно отследить поток данных.
>>3476268 >Мы не любим автомаппер за то, что то, что там происходит, слишком неявное Хуй знает, я не вникаю в ваши говнопроблемы. Нормальные библиотеки для маппинга еще на этапе компиляции кода генерируют все мапперы и фейлятся, если ты проебал сорс-дестинейшн и еще 100500 гардов, чтобы не обосраться в рантайме. А ваша хуитка от Жимми Богурда только в рантайме начинает чето там разбирать через рефлекшн и пытается смапить классы дэтэох и моделек, лол
Какие нормальные библиотеки? Сами себе проблем насоздают и потом героически их решают.
Подключаешь медиатр и внезапно тебе нельзя использовать входящее DTO в обработчике команды. Нужно его обязательно замаппить на реквест потому что вызывать методы напрямую ты себе запретил.
И не дай боже вызвать медиатр из медиатра. Тогда всё повторяется и получается ёбаная матрёшка:
dto в контроллере -> автомаппер -> команда -> обработчик команды -> маппинг в другую команду -> другая команда -> маппинг результата другой команды -> основная команда -> контроллер -> маппинг результата команды.
И где-то между этими слоями прячется логика. И в автомаппер переезжает половина логики обработки данных.
Надо быть долбоёбом с окраины с IQ 78, чтобы тушить проблему лишних слоёв автомаппером.
Пиздец, столько простых проектов загубили. Ёбаная архитектурная боггартянка. Превратили обычные круд-репозитории в зубодробительное говно
>>3476292 Не подключаешь медиатр. @ Не пытаешься эмулировать сеть внутри локального процесса, какой долбоеб это придумал, а просто напрямую вызываешь методы. @ Никакого бугурта.
>>3476319 Прикол в том, что у тебя несколько слоёв абстракции. И нельзя между ними всеми прокидывать один и тот же объект, потому что где-то надо ты поменять, какие-то данные спрятать и т.д. При этом 90% свойств перекочёвывают без изменений. И тут возникает желание, вместо того, чтобы писать конверторы ручками, взять автомаппер и написать правила типа это свойство игнорировать, это конвертировать таким кодом, а все остальные просто скопировать. Но на практике это создаёт кучу проблем. Я вообще один раз засунул веб-реквест в маппинг. Потом посмотрел на это и ужаснулся. Но переписывать не стал. С тех пор в новые места маппинг не добавляю.
>>3477968 >Прикол в том, что у тебя несколько слоёв абстракции.
медиатор не используй и не будет лишних слоёв абстракции. Автомаппер сам рассосётся.
Это ловушка такая, через неё проходили все в 2016-2018 годах. Называется архитекрурная боггартянка. Подключаешь медиатр - и его нужно тушить автомаппером. Зато код дохуя "крутой" и "правильный".
Хз, чего джунишки так дуреют с этой хуйни и повторяют старые ошибки, я бы им за такое ебало бил. Без шуток вот прямо в ебало бил ты толстой доской.
>>3477968 У тебя ровно три слоя: контроллер, бизнес логика и дата лэйер. Все. Перекладывание происходит в трех местах: IDataReader -> DTO, Request -> DTO, DTO -> Response. Первое делается автоматически дапером. Второе и третье - это одна строка result.UserName = model.UserName и у тебя работает вся навигация по коду. Автомапер не нужен.
>>3478135 >У тебя ровно три слоя: контроллер, бизнес логика и дата лэйер. Все. Перекладывание происходит в трех местах: IDataReader -> DTO, Request -> DTO, DTO -> Response. Первое делается автоматически дапером. Второе и третье - это одна строка result.UserName = model.UserName и у тебя работает вся навигация по коду. Автомапер не нужен. Ты какой-то хелловорлд описал. Между дл и бл и между бл и контроллером должны быть разные типы. В бизнес-логике объект может собираться из нескольких, например. В веб-респонсе тоже может быть свой формат из-за специфики http.
>>3478205 Ты описал паджитский говнокод уровня епам. Посмотри, как пишут охуительно быстрые сервисы на расте и голанге, там нет никаких 100500 слоев мапинга над мапингом. Одна ручка - один запрос в бд - одна дто - ебейший рпс. Да, код строится вокруг бд, потому что бд - это сердце системы и самое медленное звено. В дотнете же разработчики деградировали и разучились писать простые и эффективные программы, у всех ддд головного мозга.
>>3478218 >Одна ручка - один запрос в бд - одна дто - ебейший рпс Как на примере создания заявки я должен обойтись одним дто? При создании заявки не указывается id сущности, например, т.к. он создается в момент сохранения энтити в бд. При создании заявки, пользователю нужно отдать дто где будет id сущности. Т.е. одним дто уже не обойтись. И это первое что пришло в голову. Да и смешно слушать про какие-то там сервисы на гоу и расте где элементарно зависимости подтягиваются через таги на артифакты в гитхабе, лол
>>3478234 >При создании заявки, пользователю нужно отдать дто где будет id сущности. То есть, ты не понимаешь, как работает sql. Ты настоящий дотнет разработчик, миллионы паджитов гордятся тобой.
>>3478436 Верну джейсон какой надо. Из бд я достаю не энтити и не объекты, я достаю датасет какой мне нужен здесь и сейчас. У каждой ручки свой. Кстати, в EF Core паджиты добавили projections когда поняли, насколько обосрались с перфомансом.
>>3478939 Логика написана в сервисах, которые принимают интерфейсы дтошек. Будет какой-нибудь OrderService.Checkout(IOrderDTO), а данные в IOrderDTO каждый раз берутся из разных запросов в бд. Интерфейсы можно миксовать как угодно и у тебя все еще работает навигация по коду, в отличие от автомапера ебаного. Дело в том, что рич ООП хорошо работает на локальной машине и плохо в сети. Для ситуаций, где класс Button наследуется от Control и перегружает виртуальный метод Draw, рич заебись. Когда твои данные лежат на другой машине, их надо каждый раз загружать, а поход по сети занимает дольше, чем обработка - лучше подходит анемик.
>>3479146 У фронта две модели. Входящий джейсон - это request, исходящий - response. В сервисах модель называется DTO. В репозитори - это параметры хранимок и голый датасет, который приезжает из базы. Получил в контроллере джейсон - переложил руками в дто - что-то сделал в сервисе - передал дто в репозиторий - там внутри переложил из полей дто в параметры - вызвал хранимку - получил датасет - отмапил дапером на другое дто - вернул сервису - сервис вернул в контроллер - в контроллере руками переложил в джейсон и отдал наружу. Что писать код для перекладывания, что писать конфиг для автомапера - один хуй надо писать, только в коде работает навигация.
>>3479159 А мог просто взять автомаппер, он бы за тебя всё замаппил сам, и запросы сформировал какие нужно. ч
Или тебе нравится писать все эти перекладывания в сто слоёв? Я хуй знает, зачем вы вообще код пишете, если достаточно медиатром вызвать маппинг по хранимке... и всё.
В бушующем мире дерьма, я нашёл островок спокойствия - этот тред. Захожу сюда периодически, вижу упоминания автомаппера и медиатра и моя душа успокаивается. Пока есть на свете дебилы, использующие их, я буду цениться как специалист.
>>3479995 Нам похуй. Тебе уже кидали бенчмарки в прошлом треде где твоя джава брала с заглотом, кроме деревянных бенчмарков давящих на LOH, но даже в них разница максимум двухкратная. Небольшая цена за удобный для работы язык.
>>3480068 В чем проблема обновить спринг? xml остался в начале нулевых. Про какие "худшие практики DDD и AOP" ты говоришь? С худшими практиками можно и на сисярпе писать, если проекты на нем будут, лол
>>3480467 Клоун, твое клоуничанье не поможет убрать говно в твоих трусах >>3480468 https://programming-language-benchmarks.vercel.app/csharp-vs-java >Удобство это гет сет кококо? Так у тебя и этого нет, терпила) Не говоря про методы расширения, про нормальный ансейф и рантайм кодогенерацию, нету span<t> и структур под них. И это при том что чтобы начать юзать спринг нужно занести в кассу жижбрейну или качать крякнутые иде, иначе разрабатывать это говно ебаное нереально, поддержка сторонних иде нулевая, при том что комьюнити визуалка поддерживает всё кроме деплоя на азуру. И вообще вся инфраструктура языка похожа на парад костылей который без платной иде собрать нереально, ну это ладно, вкусовщина.
> про нормальный ансейф Не можешь себе представить жить без ассемблероподобного пердолинга, ведь в петушарпе высокоуровневых и быстрых инструментов просто не завезли? Да и нормальный он, лол.
> рантайм кодогенерацию Чаво? Лучшая среди всех языков.
> И это при том что чтобы начать юзать спринг нужно занести в кассу жижбрейну или качать крякнутые иде Спринг != джава во-первых, во-вторых миллион у тебя срыг плагинов для любых иде на любой вкус, не знаю, что за хуйню ты несёшь, для вс кода есть, для эклипса, для чего угодно, для комьюнити жидеи даже.
> методы расширения А в петушарпе они что-ли есть?
А теперь готовься реветь:
Огромная экосистема. Это включает в себя: Возможность выбора наилучшего, подходящего под твою задачу между несколькими инструментами, выполняющих похожие задачи Maven. Системы сборки подобной стабильности, удобства, качества, нет ни в одном другом языке. Новые версии Gradle тоже могли бы выглядеть как сносные системы сборки, тоже надирающих задницы системам сборки в других языках, но, увы, Gradle не умеет не ломать обратную совместимость и не внедряться в кишки JVM, из-за чего постоянно приходиться И обновлять Gradle, чтобы использовать новую Java, И бороться с поломками обратной совместимости. Инструментарий для генерации бойлерплейт кода при компиляции, по сути расширяющий синтаксис Java. Это включает в себя Lombok и Manifold, откуда мы можем взять такие вещи как генерацию конструкторов, акцессоров, делегатов, перегрузку операторов и другое. JVM. JVM является невероятно умной системой, поддерживающей самые разные языки программирования, как дающих гарантии (например, Rust), так и не дающих гарантии и требующих вмешательства со стороны рантайма (Java) с высокой производительностью. В JVM есть огромное количество сборщиков мусора на выбор, есть умный JIT, позволяющий делать оптимизации, а также мы ожидаем Project Valhalla, который должен позволить ещё сильнее оптимизировать работу кода. Java имеет приятный, OG синтаксис из времён начала программирования человекочитаемыми конструкциями, грациозно расширяемый каждые полгода и поддерживаемый в современном состоянии. Кроссплатформенность. Обратная совместимость. Джава является единственным языком, который на самом деле поддерживает многопоточность. Во всех остальных языках многопоточность является огромной бойлерплейтной болью, а гарантии через спецификацию являются рудиментарными, о которых никто не знает. Доходит до того, что пособия по многопоточности в Java являются отличным вариантом для изучения многопоточности в большинстве других языков. Java поддерживает платформенную многопоточность. Некоторые языки пошли по пути исполнения кода глобально effectively в одном потоке. Таким образом, они избавились от части недостатков многопоточности (низкоуровневых багов), ценой отказа от увеличения производительности за счёт нескольких ядер процессора, оставив многопоточность для тех случаев, когда она нужна не для увеличения производительности, а для реализации непосредственной логики. Java даёт возможность пользоваться всеми ресурсами машины. В Java есть огромнейший инструментарий для организации многопоточного flow, что регулярно расширяется с новыми обновлениями. Он настолько всеобъемлющий, что, например, на одном из классов Java были основаны все корутины в Kotlin поначалу (ForkJoinPool). В Java есть полноценная теория о многопоточности, что позволяет подходить к построению многопоточных приложений с научной точки зрения. В основном, это представлено книгой Java Concurrency in Practice. Если не понимать всей сложности темы и просто забить хуй на неё, то очень скоро столкнёшься с непонятными проблемами вызывающими сомнения в реальности происходящего, поэтому без теории не может быть никакого многопоточного программирования, а в Java теория есть. В Java присутствует решение проблемы тяжеловесности потоков общего назначения без всех минусов корутин, таких как замедление кода в 11 раз или загрязнение кодовой базы async/await/suspend приводящими к дублированию методов. Preview процесс в разработке Java, благодаря которому каждая новая фича языка выпускается наивысшего качества.
>https://www.techempower.com/benchmarks/ сурс бенчей где? Я ебу что этот паджит там накорябал и выдал за perfomance comparsion. В моей ссылке сурс есть и там по http дела у жавы не очень и сурс есть.
>А в петушарпе они что-ли есть? Есть, и очень, очень давно. И в нем еще очень много чего есть, советую ознакомиться.
>Чаво? Лучшая среди всех языков. С каких пор написание ручного генератора java файлов на основе рефлексии стало рантайм кодогенерацией? Про деревья выражений слышал?
>Спринг != джава во-первых, во-вторых миллион у тебя срыг плагинов для любых иде на любой вкус, не знаю, что за хуйню ты несёшь, для вс кода есть, для эклипса, для чего угодно, для комьюнити жидеи даже.
Пиздаболище, я их тыкал вот буквально на днях. Единственное что не похоже на говно это amplicode, за бабки, остальное неюзабельный кал. А без спринга джава впринципе не нужна, обычный недошарп. По мнению самих же джавистов эклипсы хуипсы это все неюзабельное говно и если надо работать - меньше чем энтерпрайзом жижбрейнса не обойтись.
>Да и нормальный он, лол. Нормальный != отсутствующий, пиздабол.
>В Java есть огромнейший инструментарий для организации многопоточного flow Я могу сказать какого инструмента для организации многопоточного flow у джавы нет. И у шарпа нет. Это коллекции позволяющие производить блокировку по каждой отдельной записи на чтение и монопольно на запись, не блокируя всю коллекцию, так как это делают базы данных. Приходится в итоге велосипедить. Остальное это так, пыль в глаза, еще один способ стрелять себе в ногу по новому. Корутины, асинки, потоки, а нормального решения для параллелизации работы с крупным набором данных нет, сами подгатывайте мультипоточный флоу чтобы не нарваться на гонку или на дедлок, епта.
Пасту уноси, конкретики ноль, кейсов ноль, джава все ещк недоязык.
> С каких пор написание ручного генератора java файлов на основе рефлексии стало рантайм кодогенерацией? Про деревья выражений слышал? Чего? Ты откуда это взял вообще? Опыт петушарпа проецируешь?
> Пиздаболище, я их тыкал вот буквально на днях. Поищи проблемы в межплечевом прыще.
> Нормальный != отсутствующий, пиздабол. Сам-то понял, что высрал?
>>3480545 С телефона видно не очень. Замерить бы всё что он юзает, но мне в целом похуй, тебя даже если в его паджитизм носом ткнуть ты ж все равно будешь в тред срать дальше. >Ясн Яндекс не используешь по религиозным причинам?
>Чего? Ты откуда это взял вообще? Опыт петушарпа проецируешь? Из гугления. Но тебе ничего не мешает притащить пруфы, благо это быстрее чем мне проверять что там этот паджит нахуевертил.
>Поищи проблемы в межплечевом прыще. Я знаю эту проблему, называется привык к нормальному и не знал что значит платить за инструментарий.
>>3480551 > С телефона видно не очень. Замерить бы всё что он юзает, но мне в целом похуй, тебя даже если в его паджитизм носом ткнуть ты ж все равно будешь в тред срать дальше. Слив.
> Яндекс не используешь по религиозным причинам? Какой ещё яндекс? Причём тут яндекс?
> Из гугления. Но тебе ничего не мешает притащить пруфы, благо это быстрее чем мне проверять что там этот паджит нахуевертил. Так это ты должен пруфы нести, ты же хуйню какую-то высираешь.
> Я знаю эту проблему, называется привык к нормальному и не знал что значит платить за инструментарий. Давай по кругу, пока не дойдёт: >во-вторых миллион у тебя срыг плагинов для любых иде на любой вкус, не знаю, что за хуйню ты несёшь, для вс кода есть, для эклипса, для чего угодно, для комьюнити жидеи даже.
> Конкретики всё еще нет Тебе стена текста конкретики на ебальничек вывалена.
> Конкретики всё еще нет, только куча говнокода от паджита который юзает ToList() в бенчмарке вот здесь > // Copyright (c) .NET Foundation. All rights reserved. > // Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information. Ааххахахахахахахаххахахахахаах блядь. Этот дебил только что своего барина закопал.
>>3480570 Дауненок, ты что то кроме стрелочничества знаешь? Я тебе порядочно пруфов принес. >стена конкретики >Ровно ноль буковок про технологии, обеспечивающие тот набор хуйни, вываленной взбесившимся паджитом-маркетологом Шиз, таблетки
>Ааххахахахахахахаххахахахахаах блядь. Этот дебил только что своего барина закопал. Даун не знает что такое NET Foundation. Обьясняю для тех кто не в курсе что такое поисковик - это продукты существующие в рамках программ поддержки майкрософт, но не являющиеся частью дотнета, что-то типа спринга но от условного стороннего разраба.
>>3480581 > Дауненок, ты что то кроме стрелочничества знаешь? Я тебе порядочно пруфов принес. > Шиз, таблетки Слив.
> Даун не знает что такое NET Foundation. Обьясняю для тех кто не в курсе что такое поисковик - это продукты существующие в рамках программ поддержки майкрософт, но не являющиеся частью дотнета, что-то типа спринга но от условного стороннего разраба. Ну и?
Почему мне не похуй, какой кусок говна быстрее, если всё, чем я занимаюсь - заливаю однотипный говнокод из гптшки в прод, как и 100% "програмеров" на этой доске, лол.
>>3480768 Я под однострочный for написал вот такое расширение https://pastebin.com/TJkNiB12, (ну и еще кучу ему подобных под всякие варианты итераций), но да, за представленнные в том гите такие однострочники нужно немедленно гнать в шею
>>3480839 Делаю снапшот. У меня код максимально многопоточный, не хайлоад, избегаю разрушения итератора. Можно конечно ещё оптимизировать, подтянуть блокируемые списки, но и так тоже сойдёт.
>>3480851 Если твой код многопоточный, то где блокировки? Зачем делать многопоточный цикл? Чтобы что? Это же просто сраный цикл, базовая конструкция языка.
>>3480856 А к чему блокировать снапшот? Внутри экшена и будут блокировки для его обьектов. Дело не в многопоточном цикле а в многопоточном доступе к коллекции.
>>3480900 Не, это не для такого случая. Такая конструкция нужна если коллекция может поменяться извне (добавиться удалиться элемент) и только в случаях если элементы коллекции независимы друг от друга. Параллелизация обработки такой коллекции - это Parallel.foreach и в качестве основы concurrency типы, такие как сумка/стек или велосипедный блокируемый список, чтобы не было проблем с разрушением итератора.
>>3480900 Совершенно не факт кстати, однопоточный пеформанс намного выше и масштабирование нелинейное там, 10 потоков не ускорит в 10 раз. Лучше протестируй и сравни результаты.
>>3480900 Во-первых, сишарп плохой выбор для хайперфоманса. Блокчейн на нем никто не пишет. Во-вторых, чтобы твои 10 потоков реально работали параллельно, надо все данные сериализовать в массив, чтобы вообще не было ссылок куда-то наружу в память. Потом загнать этот массив в кеш процессора и ебнуть simd инструкции. Кто будет этим заниматься в языке для попукивания в кафку - вопрос риторический.
>>3481196 >сишарп плохой выбор для хайперфоманса. У хайперфоманса градации есть. Плюсовик будет стоить в 2 а то и в 3 раза дороже. Да и к тому же так исторически сложилось что у шарпа все математические и ИИ либы сдохли, а ml.net не взлетел, потому на нём такое мисать в первую очередь больно, и только во вторую проигрышно по перфомансу. >реально работали параллельно Ты вместо реальной параллельности описал способ как избегать кешмисов при обработке массива. Это конечно очень интересно, но обычно процесс обработки элемента раз в 100000 тяжелее чем его взятие по ссылке из коллекции и нужно прям совсем экономить чтобы заниматься нарезкой коллекции на чанки array под каждый физический поток. Можно конечно и даже не очень сложно, но обычно да, это никому кроме разрабов Unity DOTS не надо. Про SIMD вообще смешно, ты сюда из /gd забрел? Напоминаю, что simd обрабатывает только типы из numerics и типы значений, задач для них у дежурного с# формошлепа нет ни одной, кроме быстрого сравнения строк/массивов, при том что в string.equal уже заложен этот функционал. Параллелизм же в первую очередь достигается формированием данных, готовых к параллельной обработке, а это самое сложное. Сложно сделать такую параллельность рентабельной, сложно достигнуть синхронизации с ресурсами, к которым обращаешься при параллельной обработке коллекции, сложно обеспечить нулевую связность элементов массива друг с другом для избежания гонки, а остальное это так, мелочи, технические ньюансы.
>>3480516 >Джава является единственным языком, который на самом деле поддерживает многопоточность. Во всех остальных языках многопоточность является огромной бойлерплейтной болью, а гарантии через спецификацию являются рудиментарными, о которых никто не знает. Доходит до того, что пособия по многопоточности в Java являются отличным вариантом для изучения многопоточности в большинстве других языков. >Java поддерживает платформенную многопоточность. Некоторые языки пошли по пути исполнения кода глобально effectively в одном потоке. Таким образом, они избавились от части недостатков многопоточности (низкоуровневых багов), ценой отказа от увеличения производительности за счёт нескольких ядер процессора, оставив многопоточность для тех случаев, когда она нужна не для увеличения производительности, а для реализации непосредственной логики. Java даёт возможность пользоваться всеми ресурсами машины. >В Java есть огромнейший инструментарий для организации многопоточного flow, что регулярно расширяется с новыми обновлениями. Он настолько всеобъемлющий, что, например, на одном из классов Java были основаны все корутины в Kotlin поначалу (ForkJoinPool). >В Java есть полноценная теория о многопоточности, что позволяет подходить к построению многопоточных приложений с научной точки зрения. В основном, это представлено книгой Java Concurrency in Practice. Если не понимать всей сложности темы и просто забить хуй на неё, то очень скоро столкнёшься с непонятными проблемами вызывающими сомнения в реальности происходящего, поэтому без теории не может быть никакого многопоточного программирования, а в Java теория есть. >В Java присутствует решение проблемы тяжеловесности потоков общего назначения без всех минусов корутин, таких как замедление кода в 11 раз или загрязнение кодовой базы async/await/suspend приводящими к дублированию методов.
Ысе вот эти вот Visual studio 20... (не важно какой версии, кроме 2017 ) и все вот эти вот эмуляторы - это всё тухлая поебень которая либо на работает вообще, либо компилируется 50 часов нахуй. А тем более visual studio Code. Я на этом VSC в жизни даже хеллоу Ворда не смог скомпилировать. Он просто не знаю даже для чего создан. А потому что "Multi " , а всё что мульти - это вроде как и для всех платформ сразу, но в тоже самое время и не для какой вообще.
Моя задача это делать примитивные программы но желательно с GUI и обязательно для двух платформ. Андроид и Винда (7я даже стоит дома) терпеть не могу «новинки». Так вот я пришёл в выводу, что для того чтобы я пользовался родным C# я обязан перейти исключительно на консольные приложения. Тупо мутить интерфейс из символов псевдографики наподобие Borland Pascal IDE если кто помнит. По крайней мере это единственный РАБОЧИЙ вариант кодинга под две платформы. БЕЗ переписывания кода, без всей этой ебаты с элементами пользовательского GUI (где а MAUI то кнопка сползла за экран, то ещё какой-то там pading отвалился, то вообще всё накрылось к чертям. Конечно, этот подход не годится для коммерческого программирование да и вообще для коммерческого сорта. Но я пишу для себя всякие автоматизатопы и парсеры и мне похуй на тренды. Зато код абсолютно идентичный получается и можно писать прямо в телефоне. Вплоть до того, что вечером дома на компе уже готовый код тестировать(после теста в телефоне). Хули толку от этого xamarina если приложения постоянно отваливаются и с ними вечно какие-то проблемы. Или к примеру от Java, если для запуска его «УНИВКРСАЛЬНЫХ» «мультиплатформенного» кода, я вынужден таскать за собой гигабайты SDK и эмуляторов для каждой платформы чтобы это всё хоть как-то запустилось
В .NET рантайм уже какое-то время как смержили CoreCLR Interpreter (https://github.com/dotnet/runtime/issues/112748). Но что-то я не вижу упоминаний по поводу того что с ним будут делать кроме iOS и WASM (по типу, выкинут ли Mono runtime, будут ли юзать интерпретатор в NativeAOT и т.д.). Кто что знает (ну и мнение)?
>>3482579 Как можно было обосраться с vsc хоть убей не пойму. Просто блять 3 простейших шага Дотнет сдк Расширение c# + c# devkit + intellisense по желанию dotnet new console Всё нахуй. Сижу на вскод последний год и решительно не понимаю в чем проблема, если для личного пользования. Wpf стал кроссплатформой, есть авалония уже очень давно. В конце концов можно поставить Target 4 фреймворк и запускать под моно винформу.
>>3481770 Что сказать-то хотел? Там про твои асинки прямым текстом написано. Это помои, которыми прикрывают свою порваную жопу шарподауны за неимением альтернатив.
>>3483286 >всё можно поднять парой строчек кода Java сервисы тоже, если написать докерфайл. Мухам в винду так и не завезли синего кита? В десятке же появился какой-то Docker Desktop вроде.
>>3484382 Мне кажется, ты не понял, что тебе написали. На ноде можно написать пару строчек кода, и оно уже будет что-то полезное делать. Для спринга и аспнета нужно больше кода. В обоих случаях начальный бойлерплейт уже есть в шаблонах, но всё равно надо что-то ещё написать. Ну и бойлерплейт, который сам создаётся, тоже довольно объёмный.
>Как просто ПОДОЖДАТЬ http запрос в джаве? var result = http.request(); Что, совсем мозг повредило асинками? Самый нормальный вариант белого человека без обмазывания кода говном уже в голову и не лезет?
>>3485171 >Асинк авейт и есть виртуальные потоки Нихуя себе. Блиииин а я то все какие-то машины состояний себе представлял и сохранение состояния потока при переключение.
Вот собственно с кем мы тут сидим. Виртуальные потоки в асинк эвейт.
>>3484815 >Для спринга и аспнета нужно больше кода.
С небольшой разницей. Дотнет просто запустится на любом современном железе, а JAVA будет ебать мозги 3-4 часа манипуляциями с бинарями, неработающим мавеном и правками в хуй знает каких xml файлах.
Собственно, мы поэтому от спринга и отказались. На вид джава почти как сишарп, но как работать начинаешь - понимаешь, что джава скорее аналог дотнет-фреймворк-4.5.2, который ты пытаешься запустить через wine.
Конечно, там автомат с состояниями, а под ним находятся таски, которые являются абстракцией над потоками. В каких-то случаях таски могут выполняться последовательно в одном потоке, а в каких-то параллельно в разных. И именно это тоже самое, что виртуальные потоки в жаве.
>>3485225 >С небольшой разницей. Дотнет просто запустится на любом современном железе, а JAVA будет ебать мозги 3-4 часа манипуляциями с бинарями, неработающим мавеном и правками в хуй знает каких xml файлах.
Да, у меня тоже такое ощущение. Куча команд типа clean, install, build, deploy, и так далее, причём делают они совсем не это. Куча источников параметров вплоть до переменных окружения (это уровень php какой-то). Куча параметров сборки без которых нихера ничего не выйдет. Нет нормальной среды разработки, которая все нюансы подхватывает. Вечно либо код красный, но собирается, либо наоборот. Ну и несколько реп пакетов без синхронизации версий. Пакет одной версии в одной репе может оказаться совсем другой версией во второй.
Откликаюсь на стажерские вакансии - нихуя. По рофлу отправил отклик на джуновскую, и сразу предложили созвон. Но я зассал, условия хорошие, но до требований я явно не дотягиваю. Компания логистическая, а у меня пет проект для логистической компании, походу поэтому и ответили. Но он довольно посредственный. Обычное рест апи, по сути можно только создавать заказы и управлять ими, а также отслеживать их. Есть система аутентификации и авторизации, распределение доступа к действиям по ролям, бизнес-логики почти нет никакой, ну расчет стоимости, а расстояние определяется через стороннее апи, юнит тесты для галочки, интерфейса нет. Насколько это кал, такое вообще стоит показывать? Еще есть программа для учёта дебиторской задолженности на wpf, делал его для мамы, так как 1с у них не было. Делал года 2 назад, с нулевыми знаниями wpf и xaml, без mvvm. Стоит его вообще указывать, учитывая, что я уже почти все забыл и особо пояснить не смогу? Просто убил на него много времени, да и получился довольно объемным (ну для меня).
>>3485621 За работодателя думать не нужно, дотягиваешь там или нет. Если только ищешь первую работу, отказываться от собеседований глупо, потому что это для тебя при любом исходе будет полезным опытом, даже если обосрешься (а сначала все равно скорее всего так и будет). Про проекты имеет смысл рассказывать, если они имеют отношение к тому, чем планируется заниматься на работе. Ну или если такого мало, то просто показать, что не совсем дурак, и что-то сам можешь сделать от начала до конца.
>>3485237 Я дотнет разработчик, которому очень редко приходится что-то делать с джавой. У меня, конечно, колоссальная разница в опыте между шарпом и джавой, но как правило почему-то когда я беру где-то шарповый код, то его можно просто открыть в вс и запустить, нажав f5, а с кодом на джаве так не получается.
>>3485753 А ты понимаешь, что ядро не дает квант времени потоку, который ждет ответа на сисколе? Легковесные потоки - это просто дань моде, а так ты спокойно можешь запустить 1000 тредов или даже форкнуть 1000 процессов, повесить их на один сокет и все будет работать без хитровыебаных асинков.
>>3485879 >>3486156 Если охота работать конкретно на линуксе, то см. пик. Если на винде то тот же самый набор + visual studio (имхо лучший выбор). Часть c# разрабов вообще на маках работает, но в душе не ебу, что они там сейчас используют. Вроде должен быть тот же набор, что и для линукса.
>>3486026 >Код пишется под виндой, но на проде работает под линуксом. И что тут не так? Или ты к примеру разрабатывая под андроид будешь код у себя на телефоне писать? Спокойно все пишется на одной системе и запускается на другой. Даже отладка удаленная с винды на линукс/докер/wsl замечательно рабоатет в реальном времени.
Райдер работает охуенно. Его для wayland рекомендую немножко подстроить: Menu->Help->Edit Custom VM Options... Откроется редактирование, для поддержки Wayland добавить строку -Dawt.toolkit.name=WLToolkit
Реальная проблема разницы операционных систем у меня была только одна, - когда я забыл, что в линуксе таймзоны называются по другому и надо работать с ними через пакет TimeZoneConverter
Нативный докер экономит несколько гигабайт памяти
Линукс сам по себе нетребовательный к ресурсам и предсказуемый. Он не перезагружается внезапно, не лезет в интернет, чтобы скачать что-нибудь.
>>3486229 А еще в линуксе нету виндового костыля ограничивающего шаг таймера на 15мс, и в итоге Task.Delay сжирает 1 ядро проца пока его не отпустит, но это так, просто неприятный ньюанс.
Кроме того, представитель Microsoft прокомментировал дальнейшую судьбу .net core. Слухи о том, что .net 10 будет последней версией не соответсвтуют действительности, а массовые увольнения сотрудников не повлияют на поддержку проекта...
Это всё... Microsoft полностью переходит на python и typescript. Ведь там есть эйай... А что мы, жалкие скуфи, нас высех выкинут на улицу, а JS разработчики будут ездить на кабриолетах...
Блять решил поизвращятся и пощупать виндовый современный ГУЙ фреймворк. Тыкаю пустое ВинУИ апп, и сначало ахуеваю от 100 мегабутов на пустое окно, а потом ахуеваю что оно блять ТИЧОТ. И это даже блять не превью и не альфа билд этой залупы. На гитхабе двухлетнее ишшью висит где полтора Джона пердолятся и пытаются это пофиксить, но безуспешно и ни одна черномазая, срущая, индусская рожа даже не ответила. Я конечно знал что они ебнутые, но не настолько же.
Эти индусы захлебнулись в ЛГБТшном АИ угаре там? В мае обещали убрать плату за регу дев аккаунта в своем сторе. Уже 5 июля, а они продолжают бабло стричь.
>>3485232 Каким нахуй коллбекам? Виртуальные потоки за тебя всё делают.
> Охуеть, оправдание, конечно. Ты фреймворк пишешь или рабочий код? Подумай пожалуйста над негативными последствиями дублирования кода. Или хотя бы изучи это, если думать нечем.
Сегодня начал переводить проект на EF с внутренних велосипедов. У какая же у людей анальная кантузия от всех этих "внутренних фреймворков". Сидят предлагают засунуть EF в разные репозитории и прочие залупы накрутить поверх уже готовых строительных блоков от Microsoft.
>>3495334 Недавно на линкедине стали мелькать в ленте посты от разных MVP про плохой даппер и быстрый ефкор. Какому-то главному паджиту походу печет, что два еврея 10 лет назад написали охуенный даппер и он до сих пор топчик, пока стадо индусни пилит ефкор и допилить не может. Напоминает историю с микрософт браузером, который тоже пишут онли паджиты и который никому никогда нахуй не нужен. Даппер отлично показывает уровень экспертизы. Кто пишет продукт - все за даппер, потому что заебались писать sql через сраные экспрешены, а потом отлаживать хуй пойми как. Макаки с аутстаф галер - все дружно топят за ефкор, ведь в проектах на три месяца даппер слишком большая пушка.
>>3495353 >писать sql через сраные экспрешены, а потом отлаживать хуй пойми как. Зачем мне что-то отлаживать если у меня нулевая нагрузка при запросах и скорость работы запредельная?
Твой ебучий дапер сделали долбоебы потому что если мне нужен будет сырой sql я руками могу написать все это на ado.net без всяких библиотек с оптимизацией под моё приложение. Я не понимаю нахуя мне костыли в виде даппера хуяпера который режет яйца если я могу писать все сам на низком уровне как мне надо. Но мне не надо. Потому что те -Nмс что я выжму из ado.net не стоят того чтобы отказаться от EF.
Ну и да с твоим даппером нахуй идут любые спецификации и следовательно ты будешь весь код обмазывать 100500 имплементацией фильтра по "нерелеватный статус" и скакать по коду в поисках где эта залупа еще была. Я же меняю список класса InvalidStatusSpec и все 200 мест его использования сразу будут с новой логикой которая работает и с Enumerable и с Querable и с отдельными классами.
>>3495353 >заебались писать sql через сраные экспрешены, а потом отлаживать хуй пойми как Ты хлебушек? Экспрешены, то ты как раз и можешь отладить в IDE, в отличие от ебучего sql.
>>3495364 >нулевая нагрузка при запросах На локалхосте она у тебя нулевая. На проде ты охуел бы, если бы твой галерный проект когда-то добрался до прода.
>руками могу написать все это на ado.net И руками мапить user.Name = reader["Name"].ToString() снова и снова. Отличный план. Даппер для этого и нужен, чтобы ты не страдал хуйней.
>спецификации Продолжайте в том же духе. Наша контора так заполучила жирного кастомера. У них была система, сделанная адептами DDD, может даже вашим епамом, эта хуйня дико тормозила на продовых данных. Наша система летает потому, что построена вокруг бд, а не вокруг мокрых фантазий о чистом коде, в итоге с нами подписали контракт. Вы все правильно делаете, больше говна богу говна.
>>3495353 Я пишу продукты уже больше десяти лет, и я считаю, что sql в подавляющем количестве случаев нахуй не нужен, достаточно всё в монге хранить. И то, что для тривиальнейших вещей приходится писать километровые запросы с пятьюдесятью джойнами, а потом это ещё рекомбинировать из табличной в иерархичную структуру, это подтверждает. Ну или ебаться с еф, который тоже такой ебучий из-за несоответствия форматов данных.
>>3495364 Суть даппера в том, что легко можешь замаппить результат на класс, что радикально сокращает количество бойлерплейта.
>>3495382 >в монге хранить Ммм, эти версии записей, эти простыни кода для обработки. Потом оказывается, что мы неправильно поделили данные и теперь нужна еще одна бд для аналитики. В sql это был бы просто джоин, но мы не ищем легких путей, прикрутим эластик и кликхаус, прикрутим еще раз. Потом данные разъезжаются, ведь асида из коробки у вас нет и консистенси - это ваша проблема. Такие-то вайбы финтех стартапов.
Ещё одна пидорская секта. База данных из рекламного буклета. Эти долбоёбы настолько преисполнились, что объявили реляционные базы данных ЛЕГАСИ.
Я с утра пытался положить просто JSON объекты в монго, и после двух часов гомоебли с конвертацией JSON в BSON выкинул это говнище и просто в постгре сложил.
В рекламном буклете появились. Там столько оговорок, что оказывается, что транзакции в монго работают только в одной реплике и только если в момент их обработки нет конкурентного доступа к данным.
Так же как и констрейнты, которые в монго в некоторых случаях не работают
>>3495380 Ты действительно хлебушек. Я в курсе что такое план запроса и как с ним работать. Разговор был про отладку которую в разы удобнее делать в IDE и на нормальном языке программирования. Для SQl тупо нет нормальных средств отладки. А твои планы запроса, это уже больше про оптимизацию готовых запросов, а не их отладку.
>>3495401 Если совсем нулевый, то 60К испыталка, 80...100 после. Если с опытом то от сотки. На большее ты сейчас только по связям залетишь или если удачно на какой-либо срочный денежный проект залетишь. Но там придется напиздеть, что ты уверенный мидл и пройти соответствующий собес.
>>3495465 А ещё я могу одним движением руки заменить реальную БД на коллекцию в памяти или контекст в памяти и отладить код. С сырым sql ты можешь пойти нахуй, написать юнит тесты на это невозможно, никакой статической проверки твоих запросов и типов нет. Как там в даппер кстати решается проблема когда необходимо дать фронту возможность задавать поля и направление сортировки по нескольким полям?
С сырым sql тебя могут пидорнуть SQL инжекшеном. EF в том числе для безопасности используют.
> Как там в даппер кстати решается проблема
В даппере вообще такой проблемы нет. Просто берёшь Dapper.Automapper, и с помощью экспрешшенов пишешь запрос, а автомаппер за тебя все поля маппит и фильтры делает.
>>3495957 Джун, так и должно быть. Пробрасывать IQueryable до контроллера - это красный флаг и метка мартышки. Репозитори - это не абстракция таблицы в бд, как пишут паджиты, это абстракция ВСЕЙ базы. Не IQueryable<Order> IRepository.GetOrders(), а List<OrderDTO> IRepository.GetOrders(ITransaction t).
>>3495988 DbSet это и есть реализация репозитория, а DbContext это реализация паттерна uow.
В проекте делаешь IQueryContextFactory и ICommanContextFactory. Внутри через. DI получаем pooled или обычную фабрику контекста. Оборачиваем вызов CreateDbContext() добавив AsNoTracking для запросов и делаем метод который автоматически добавляет транзакции и заварачивает твой код. Дальше все это через DI получаем где надо и пишем await using var context = await _contextFactory.CreateDbContextAsync(); Погнали писать запросы.
Если ты завернул вызов EF в Repository, то поздравляю ты долбоеб паджит который где-то слышал про репозитории и не понимает для чего они нужны. Если тебе требуется повторно использовать фильтры, то велком писать спецификации, а не городить хуйню из DAL слоя в .NET.
>>3496029 Ебаный пиздец, ты высрал фабрику фабрик, чтобы просто сделать селект. Еще небось сверху обмазал автомапером, а то недостаточно круто. Хорошо, что я перекатился на голенг, там такой шизы нет.
При этом хорошей практикой считается если Агрегат сам может быть репозиторием. Это даёт чистое разделение ответственности и избавляет от антипаттерна анемичных моделей
>>3496029 >Если ты завернул вызов EF в Repository, то поздравляю ты долбоеб паджит который где-то слышал про репозитории и не понимает для чего они нужны.
У меня был долбоёб один, который так сделал. Он буквально инжектил везде по 3-10 UOW вот так
Он греко-киприотом был. Я его спросил, которым из них надо коммитать, он ответил какой-то набор слов про HEXAGONAL CLEAN DDD ARCHITECTURE, я посмотрел на этот долбоебизм ещё пол года и уволился нахуй
>>3496078 >высрал фабрику В смысле высрал. Это стандартный способ использования EF. Регаешь через AddDbContextFactory фабрику контекста и через неё получаешь контексты. Если у тебя хай рпс, то pooled.
DbContext это еденица работы. Каждый твой метод сервиса должен создавать новый контекст. EF оптимизирован для того чтобы ты мог создавать тысячи контекстов в секунду. Стандартный размер пулла контекстов это как раз 1000 штук.
>>3474778 (OP) Я был простым прогером петухон + голанг, но месяца 3 назад пришлось в связи с задачами перейти на дотнет. уже писал на нем раньше к сожалению Я ебал в рот ваш дотнет, бойлерплейтный кал, сосите мои пальцы, пидарасы, 5 дней в неделю я трогаю кал. Я больше не хочу трогать ваш кал, с понедельника я уволюсь и больше не буду прикасаться к вашему калу с медиатром, еф кором, автогенерацией обработчиков. Буду отдыхать до следующей весны, а там начну разводить кроликов у себя на гектаре. Пейте мочу, рабы мелкомягких.
На самом деле против дотнета ничего не имею, просто противно на нем писать, пользоваться его тулзами. Так что уволюсь и отдохну.
>>3495439 Это переписывается в виде экспрешенов, наркоман. Тебе боженька балмор дал linq, зачем ты эти билдеры городишь?
>>3495443 Ещё раз. Если тебе надо кучу реплик с транзакциями, у тебя там гостайны или банковские балансы, ну храни это в реляционной бд. Не надо граничные случаи придумывать. У 90% сервисов нет никаких гонок за конкретными записями, а вероятность нарушения консистенси даже без каких-то специальных мер ниже, чем вероятность падения метеорита на датацентр.
Ты долблёб, проблема дублирования при одновременной поддержке синхронного и асинхронного апи может возникнуть только в случае когда у тебя публичная библиотека.
Когда пишешь рабочий код, ты просто удаляешь лишний метод.
> Thread.startVirtualThread(() -> sharpFly.obossat("Нихуя себе проекции, лол."));
Предположим, я с помощью атрибутов задаю правила валидации в дто, в контроллере проверяю ModelState. Надо ли мне еще раз валидировать в сервисе по тем же правилам? Как принято вообще? Чат гпт говорит, что не надо, а дипсик что обязательно надо.
>>3498963 По чистой архитектуре надо. Вдруг у тебя, ну, cli вызовы будут, по gprc, итд. Ядро должно быть консистентным всегда. оно знать не знант, что ктото выше чето провалидировал. но как всегда it depends
>>3499608 че-то про ELK ( я вопрос даже не понял потому что не знал аббревиатуру эту) опен телеметри че это
ну и с хр забыл про слово интернирование, но смысл значения нет ей объяснять, она не разраб, так бы меня чел по ту сторону понял и засчитал бы ответ. пиздос. 200к рублей собес на мидла
>>3499883 И шо? Сейчас бы доебываться до размера кода. В голанге весь код - это бесконечные портянки с err != nil, ужас ужас. Тем не менее, опытные разработчики массово перекатываются на го, в дотнете остаются дауны, которые не знают, чем select * отличается от select id. На голанге пишут нагруженные сервисы, на сишарпе сидят пускают слюни в автомапер, потому что кадры решают, а не синтаксический сахар.
Попробовал сделать middleware для глобальной обработки ошибок, но в режиме отладки он не срабатывает нихуя, вываливается в исключение. Это норма? Почему в гайдах, у всех работает и в режиме отладки тоже?
>>3500064 >Попробовал сделать middleware для глобальной обработки ошибок, но в режиме отладки он не срабатывает нихуя, вываливается в исключение. Это норма? Почему в гайдах, у всех работает и в режиме отладки тоже?
>>3500088 Да, уже понял. Вчера весь день убил, пытаясь решить эту несуществующую проблему. Хз, челы в своих гайдах могли бы и упомянуть, что нужно без дебага запускать.
>>3500064 >глобальной обработки ошибок А хули с ними делать? Для логирования можно просто врубить стандартный функционал и сразу еще настроить откуда какие логи собирать и куда их слать.
>>3500116 Не, это хуевый подход. Глобальный обработчик ошибок больше нужен для отлавливания какой-нибой непредвиденной хуйни, чтобы у тебя тупо сервис не упал из-за того-что где-то непредусмотренный таймаут или что-то еще выскочило. Вот нахрена тебе к примеру тащить какой-нибудь ConsumeException из кафки и логику его обработки на самый верх, когда проще его обработать там где у тебя работа с ней ведется и просто самому гарантировать, что оттуда никакой эксепшен не выскочит.
>>3500144 >Не, это хуевый подход. А у вас никогда не было такого, вот читаешь, учишь как надо. Потом смотришь другой источник, там говорят, что это хуйня, надо по-другому. Переделываешь. Потом смотришь третий, там пишут, что это тоже хуйня, надо вообще иначе. Почему вот с программированием постоянно так?
>>3500116 >трай кетчи по всему коду это кал и можно исключения обрабатывать в одном месте. Больше слушай долбоебов. Исключения надо ловить там где он происходят и ты их ждёшь, причём типизированые и писать нормально логи контекста этого исключения.
Тем более маразм это try catch в корне вызова. Ты таким макаром перфоманс в 0 просто убиваешь потому что это очень дорогая операция.
>>3500165 Можно сделать что угодно. Я говорил о том, что ловить эксепшены в отдельной мидлвари можно, но тащить туда именно их обработку со всех слоев - такое себе занятие.
>>3500202 Постоянно, но ведь так веселее. Иначе разработка была бы весьма унылым занятием. Опять же любой подход это всего лишь инструмент для которого есть своя область применения. Даже для goto можно найти ситуацию которая сэкономит тонны кода, времени и тактов.
>>3500611 >то это поломанная инкапсуляция. Ты долбоеб. Проперти с get-set-init как раз и есть чистейший пример нормальной инкапсуляции. По сути это и есть контракт который ты выставляешь наружу закрывая им детали реализации того что в реальности у класса там под капотом за этим проперти содержится.
>>3500639 >закрывая им детали реализации Так ты гет-сетами наоборот, открываешь детали и показываешь, что там у тебя внутри класса творится. Доступа к полям, даже через промежуточные методы, быть не должно, если ты нормальное ООП хочешь, а не его подобие.
>>3500636 Но знать про анемик может и тот кто его не любит >>3500639 Нарушают инкапсуляцию, потому-то сеттеры выносят логику изменения состояния объекта извне, потому что позволяют частично и произвольно изменить состояние объекта. В идеальном случае должен быть один метод, который делает всю работу за одни вызов.
>>3500664 Но это только в твоей картине мира. В ФП инкапсуляция не нужна. ФП приложение это либо 1) один огромный стейт и куча операторов, функционалтных апдейтов, которые применяются к стейту через рекрсивный вызов main функции. А логика выбора оператора на каждом шаге рекурсии обычно через паттерн матчинг состояния делается. 2) однопроходная функция с вводом и выводом данных
>>3500703 >Но это только в твоей картине мира Расскажи про свою, где инкапсуляция сохраняется. Про ФП я ни слова не писал, не знаю зачем ты мне про него расписываешь.
>>3500703 >Но это только в твоей картине мира. В ФП инкапсуляция не нужна. ФП приложение это либо >1) один огромный стейт и куча операторов, функционалтных апдейтов, которые применяются к стейту через рекрсивный вызов main функции. А логика выбора оператора на каждом шаге рекурсии обычно через паттерн матчинг состояния делается. >2) однопроходная функция с вводом и выводом данных
Всё правильно, только ФП в DDD не предусмотрен и не используется
>>3501318 >Зачем тебе кстати гетсет если проперти публичные? Потому что свойства блять это блять не поля класса. У тебя при сборке свойство разворачивается в приватное поле, метод сеттер и метод геттер. Тебя не смущает что свойства могут быть частью интерфейса и их сеттер геттер могу иметь атрибут доступа, а еще к они могут быть виртуальные и абстраные. Прям как методы.
>>3501331 >Тебя не смущает что свойства могут быть частью интерфейса и их сеттер геттер могу иметь атрибут доступа, а еще к они могут быть виртуальные и абстраные. Прям как методы.
Это для чего? Чтобы DDD программировать? Когда у объекта 5 методов и 10 свойств?
>>3501333 Блин, до чего же ты тупой. Это нужно, чтобы можно было писать user.Name = "джавадебил" вместо user.setName("джавадебил"). Я понимаю, что у некоторых ООП головного мозга и они бы не прочь писать 5.multiplyBy(3).subtract(2), но нормальные люди так писать не хотят. А поля не используют, потому что инкапсуляция. Ты можешь развернуть сеттер в код и добавить какую логику не нарушая сигнатуры, точно так же, как и с лобковым set-методом.
>>3502243 Каждый раз проигрываю с этого манямирка. Кто и для кого придумывает это байтоебство? Аудитория дотнета - это дебилы с автомапером, они в локальном сука процессе умудряются делать вызовы через медиатр. Место дотнета давно у параши рядом с руби.
>>3502390 Не для тебя, ведь тебе в джаву нихуя не завезли и тебе и так нормально работать с срущими в память буферами, а то что перфоманс будет соответсвующий - да похуй, стерпят, не игры же делаем, фпс не важен.
>>3502447 Джунишка, никто на сишарпе не пишет блокчейны, кванты и прошивки для дронов, это литерали язык для попукивания в кафку. И даже тут он проигрывает джаваскрипту, ебаный стыд. Смешно говорить о перфомансе хуйни, которая сначала отжирает кучу память просто так, а потом в любой момент может встать раком и начать шуршать собирать мусор.
>>3502495 >отжирает кучу память просто так Твоя джава хуйня жрёт в разы больше. У нас сервисы на 500мб памяти работают, жрут не больше 200 обычно под нагрузкой.
>а потом в любой момент может встать раком и начать шуршать собирать мусор. Современный дотнет уже давно умеет собирать мусор без остановки потока приложения. И да как-будто твоя хуежава не собирает мусор.
>>3502390 >байтоебство Ну escape analysis и object stack allocation (и девиртуализация нормально так помогает), могут сработать в любом твоём говнокоде и улучшить производительность, уменьшить аллокации и т.д., при этом всё что нужно сделать, так это обновиться до нового дотнета.
>>3502495 >Смешно говорить о перфомансе хуйни, которая сначала отжирает кучу память просто так, а потом в любой момент может встать раком и начать шуршать собирать мусор. Ну вот в новом дотнете эта хуйня будет меньше отжирать памяти и вставать раком чтобы собрать мусор. Ну а некоторым рукожопам сколько мощностей не дай их код всё равно будет тормозить, что тут сделаешь?
Ну вот к примеру есть у тебя метод Sum(IEnumerable<int> e). Вот JIT сгенерит код, это код немного поработает и соберёт инфу о том что в твой метод почти всегда приходит List<int>, ну и JIT перкомпилит код вставив проверку на этот лист, и соответсвенно оптимизирует код под него. Вот тебе бесплатный перф. Что тебе не нравится?
>>3502531 Еще раз: никто не пишет высокопроизводительный код на дотнете. Литерали никто. Криптоскам пишут на расте. Кванты на плюсах. Драйвера на си. У этих людей нет проблемы эффективно посчитать сумму массива, это только в дотнете дебилы без автомапера и ефкора хелоуворлд не напишут. Эти твои микро оптимизации до пизды, один хуй сверху навалят медиатора, ддд побольше, и чтобы 50 микросервисов висели на кафке, больше кафки богу кафки нахуй. Ебланы из майкрософт сначала убили нахуй репутацию языка, зафорсили как язык для тупых паджитов, а теперь чето зачесалось. Поздно метаться.
>>3502536 > один хуй сверху навалят медиатора, ддд побольше, и чтобы 50 микросервисов висели на кафке, больше кафки богу кафки нахуй
а может и не навалят. Прикол дотнета в том, что ты можешь реализовывать код с такой производительностью, какая требуется под задачу.
Дотнет это золотая середина всей вашей хуйни. Мода меняется. Вчера в моде был nodejs+typescript, сегодня python. Дотнет просто стабильно в топе по популярности.
>>3478218 господи как же этот мужчина шарит мимо пишу всю жизнь на controller/service/repository, дто для request/response в контроллере, дто для бд по ситуации всё летает нахуй
Да хуй с ним, насколько оно быстро-медленно работает.
Там же с этим вашим DDD и автомаппером хуй чего разберёшь. Тупо падает не производительность кода, а производительность разработчика.
Откуда берётся свойство - хуй знает.
В каком из пяти слоёв вносить изменение, когда все пять слоёв высосаны из пальца - тоже хуй знает
Я ебал всю эту многослойную поеботу, когда для того, чтобы замаппить таблицу и внешний запрос требуется 3-4 раза вызвать автомаппер, а часть кода должна каким-то ебучим образом вызваться САМА в декларативной форме через эмуляцию рэббита внутри процесса.
Все эти обоссаные доменные сервисы, с трёхслойными дженериками подходят только для простейших круд-репозиториев.
Но простейшие круд-репозитории можно и без этой хуйни писать.
Ебать, эта такая боль была, когда мне после первой работы, где мы три года ебались с медиатором ОБЪЯСНИЛИ, ЧТО ВЫЗЫВАТЬ NEW МОЖНО, и свойства можно просто проставить из одного объекта в другой.
Я теперь пишу простейший CQS на стандартном контейнере и уже год нет проблем
>>3503129 >медиатором ОБЪЯСНИЛИ, ЧТО ВЫЗЫВАТЬ NEW МОЖНО Как в твоей шизофрении связаны медиатор и вызов new? Фабрики сущностей пишут когда для создания требуется вызов еще 5 других сервисов и логики на 200 строк. Вот чтобы каждый раз не писать все это пишут фабрики.
>>3503180 Так, что вся эта пиздобратия ходит под ручку.
Подклчюаешь медиатр - требуется автомаппер, в уме держишь DDD, а в контроллерах у тебя гексагональный эвент-сорсинг, а чистая архитектура погоняет BestPractices
>>3474778 (OP) Сап, шарпаноны, в универе учим Java, но в городе толковых вакансий по ней нет, хотя, собственно как и на .NET, везде от 3 лет опыта. Я просто хотел бы поинтересоваться, как по вашему мнению, на чем легче найти первую работку, любую, мне хочется хотя бы полгодика опыта наработать до конца ВУЗа. Спасибо
>>3503192 На 1С)))) И нет, это не шутка. Ну и кстати неплохой старт в финтех, когда видишь цельное и достаточно простое финансовое приложение, хоть кривое косое и медленное.
>>3503192 На джаве больше работы >>3503247 > Пойди на джаве поработай, посмотри этот ёбаный цирк с абстрактными фабриками билдеров посетителей DDD Эвент-сосинг На шарпе то же самое.
>>3503366 >На джаве больше работы Ага, попизди мне. На джаве дохуя вакансий, на рабских галерах, где всё уже свершилось 10 лет назад и осталось только нести крест за мамкиных ООП архитекторов, которые говна понаписали и съебались
Джава ужасна, это всегда пропёрженое легаси, которое само поломалось, а затем само починилось
У меня. Весь форкес 5 лет назад массово начал вались с джавы. Беки для мобилок, беки для небольших сайтов. Банки, озон, майндбокс, сбер, альфабанк, тинькофф. Дохера кто валит с джавы
>>3503129 только ради тебя спиздил с работы два класса: первый и ебейший public abstract class GenericGisUiPrepareExportDataThread<ItemKey extends GenericGisObjectKey, GisExportData extends GenericGisResultObjectData<ItemKey> & GisRequestData<GisExportResultData,ItemKey>, GisExportResultData extends GenericGisResultObjectData<ItemKey>, GridItem extends GenericGisExportGridItem<ItemKey,GisExportData,GisExportResultData>, DataProviderType extends DataProvider<GridItem,SerializablePredicate<GridItem>>> implements Runnable
второй и менее ебейший public class ProcOrgNsiWorksExportPrepareGridExportDataThread extends GenericGisUiPrepareExportDataThread<GisWorkExportObjectKey, GisRequestNsiWorkExportData, GisRequestWorkExportResultData,ExportWorksGridItem,ListDataProvider<ExportWorksGridItem>>
ебало моё представляешь? первая работа, 1.5 месяца уже работаю - один хуй тяжко
По сути тебе нужно освоить как пишутся агрегатные DDD сервисы, когда ты создаёшь один общий сервис для всех своих сущностей, а поведение добавляешь через спецификации, AOP или прочие практики метапрограммирования
Почитай как запускать шину сообщений, которая может паблишить события как внутри текущего процесса так и по кафке
>>3504505 >шину сообщений внутри текущего процесса Ебаный пиздец! Можно сколько угодно заниматься эскейп анализом и дрочить бенчмарки, но в реальности приходят паджиты и мажут код толстым слоем ддд говна.
Аноны, как из джуна стать миддлом? Работаю сейчас в конторе, у которой свои самописные технологии монолит еще с 2011 года. Современных фреймворков и инструментов тут нет. То есть опыта по современному стеку я тут не получу. Что делать? Самообучаться только?
Анон, поясни пожалуйста за этот момент, потому что я сейчас ёбнусь с этой чёрной бухгалтерией. Итак, есть некое целое число. Мы отправляем это число в отдельный метод, где оно должно быть разложено на составляющие его числа (например, число 123 раскладывается на 1, 2 и 3). Я решил сделать это через строку, т.к. оно попазалось мне лёгким. В результате, я засовываю переданное в метод число в некую строку, затем вычленяю из этой строки нужный мне символ, и с помощью метода Convert преобразую этот символ в число. В итоге, метод выдаёт мне какую-то хуйню. И что самое странное - этот же код, написанный в main, работает корректно, возвращая мне нужное число из строки. Я долго не мог понять, почему в мэине всё работает, а в методе начинает творится хуйня. В итоге, я установил, что всему виной операция + "\n" в мэине. Т.е. перенос на новую строку. Я хз, как это работает, но с припиской "\n" в параметре метода, оно начинает выдавать корректные значения, а без него - хуй. Как это вообще работает?
>>3504740 Ты берешь char из стринга. В мэйне с "\n" ты превращаешь char в string, поэтому все корректно. Когда ты приводишь char к int, он дает тебе код char'а. Видимо, getInt32 работает таким же образом. А вообще ты можешь просто разделить число на цифры операциями % и /.
>>3504765 Спасибо, теперь понятно. Один только вопрос - а использовать "\n" в параметре метода Convert -это вообще считается дурным тоном? Потому что, как мне кажется, оно здорово облегчает эту ебаторию. Касательно реализации через деления числа (тот же %) - я думал про это. Но мне нужно было сделать всё через рекурсию, и я не сообразил, как сделать на каждом вызове так, чтобы из исходного числа (которое, в идеале, может быть любой длины) каждый раз бралось нужное число. Через строку это показалось проще, т.к. она просто массив символов, и ничего делить не надо.
>>3504772 Дурным тоном считается конвертировать литерал в число которое литерал представляет через конвертацию именно этим апи. Для такого есть int.Parse, float.Parse и т.д. включая возможность уточнять форматирование числа (например точка или запятая для плавающих чисел или разбиение разряда). Делай по документации, не по документации не делай.
>Мы отправляем это число в отдельный метод, где оно должно быть разложено на составляющие его числа (например, число 123 раскладывается на 1, 2 и 3). Я решил сделать это через строку, т.к. оно попазалось мне лёгким. Это полный пиздец! С одной стороны у нас люди которые претендуют на роль программистов, но при этом не понимают отличие цыфры от числа и не знают как разложить число на цыфры. С другой стороны у нас AI который постоянно галлюцинирует.
>>3504801 Я, конечно, обосрался с тем, что обозвал цифры "числами" в своём посте (и нет, я различаю эти понятия на логическом уровне, просто невнимательно написал). Но ты, чучело, дважды написало "цифры" через "ы". Это тоже многое говорит о тебе. А уж сопоставлять обучение типичного вкатуна на начальной стадии с такими широко идущими выводами, типа "ох, измельчал современный программист" - это вообще пушка.
>>3504808 >типичного вкатуна на начальной стадии Типичного школьника ты хотел сказать, эту хрень сейчас в 7...8 классе проходят. Для вкатуна перед тобой уже не должно подобных проблем вставать.
БАМП ВОПРОСУ >>3504690 Хочу понять, что делает джуна мидлом. Можно ли искусственно без опыта стать мидлом? Какие вумные книжки и статьи на хабре нужно читать? >>3504798 Раз этого требует современный бизнес, то почему нет. Я хочу быть востребованным и нужным.
>>3504899 Никак. Только практика, только шишки. Книги тебе пробустят теорию, а практику - либо пиздуй на гит и смотри что там выложили индусы для всяческих курсов либо слушай подкасты/митапы бывалых энтерпрайз каломесов и пытайся на коленке собрать какой-нибудь прототип. На гите найти что-то вменяемое навроде готового продукта почти нереально, потому что это такая область где 99% кода - это каловая смесь из репозиториев с сущностями к которым прикручены ручки с кешами и всё накрыто nda.
>>3504690 >как из джуна стать миддлом? Очевидно, получить оффер на мидла. Крути опыт, ходи по собесам, к десятому будешь отвечать как боженька. Я, блять, на стафф инженера сейчас собеседуюсь по голенгу, имея ноль лет опыта в этом самом голенге, а ты на мидла стесняешься. По поводу технологий: везде в продукте будет свой самописный стек, это нормально. Модные крутые актуальные штуки есть только на галерах, где проекты по 3 месяца.
>>3504899 >Раз этого требует современный бизнес Современный бизнес требует, чтобы сделано было вчера, а не конкретные технологии. В большинстве случаев тебе дается минимальный срок на то, чтобы разобраться и сделать. Вот на навык быстро найти информацию, обработать её, понять и применить и дрочи.
Солон уже сто раз пожалел, что ушел от смешанного туалета и платежеспособной аудитории. У него сейчас буквально два флопа подряд идут, вайфуэнджоеры не платят почему-то...
>>3496961 >Ещё раз. Если тебе надо кучу реплик с транзакциями, у тебя там гостайны или банковские балансы, ну храни это в реляционной бд Так и скажи что база данных для тех кто помимо пуканья в кафку хочет пукать еще куда-нибудь. В какое приложение не плюнь - остатки, баланс, обороты, даже в аналоге джиры надо посчитать кпи.
>>3505452 можешь это рассматривать как разновидность перегрузки оператора присвоения. Ах да, у джавы же нет перегрузки операторов. И много чего еще нет. Только обмазываться анотационной кодогенерацией и дрочить остается, получается, зато по кайфу и все понятно.
>>3505491 >вот какие вы лохи, вам не завезли нечитаемости кода, сидите разрабатываете реальные программы вместо того чтобы разбираться что эта строка значит мда
>>3505523 >вжжжж инструкции на = и копроасинки это хорошо яскоооозал и буду повторять каждый день потому что если не повторю хоть раз наступит кризис среднего возраста
>>3505537 Над шарпосвиньями издеваюсь просто потому что они никак проглотить не могут и продолжают слать мне уведомления. Я даже на сосач не захожу сейчас особо, но как раз в неделю захожу так кто-то тут рыло под мочу подставил в этом ИТТ треде.
>>3505532 >писать программы >не страдать взаимоисключающие понятия для джаваговна. Впрочем как скриптовый язык для создания ручек, сущностей, репозиториев и иногда обращения к системному io - под пиво покатит, 1с похуже >>3505540 ты даже не знаешь что такое синхронизация результатов асинхронных и многопоточных функций, ты просто залетуха чуханская на которую тред не ссыт из брезгливости, ведь говно лучше не трогать - воняет
>>3505550 > Обоссал все нахрюки с пруфами. Как? Можешь последовательно объяснить свою позицию? Смотри, я ушёл с джавы на c# и очень доволен. Мне нравятся асинки, нугет, и в целом он получше устроен.
Можешь меня убедить в обратном или тебе просто неприятно?
>>3505240 Я имел в виду конкретно деньги, которые нельзя терять вообще. Для всего остального та мизерная разница в надёжности между sql и монгой вполне оправдана упрощением кода, что само ведёт к уменьшению богов.
>>3505397 >> user.name("шарпосвинота") >Ну хз хз. Мне кажется во втором покороче. Лобок генерирует setName(). Если ты хочешь делать name(), у тебе придётся писать реализацию самому. private String m_name; public String name() { return m_name; } public void name(String name) { m_name = name; }
>>3505656 >Я имел в виду конкретно деньги, которые нельзя терять вообще получается принтер за n денег который по милости отсутствия в монге способов атомизации задвоится или уйдет в минус в управленческом учете не так и страшно, да? Да, шанс на самом деле мизерный, но все же есть. Получается что за консистентность в нашем говне которе почему то называется бд для работы с важными данными, в ответе только господь бог, планировщик потоков и разраб, которому не повезло. При этом по скорости будет сосать у редиса. Так зачем же?
>>3505683 Сохранение целого документа -- это одна операция. У тебя может возникнуть инконсистентность при сохранении нескольких документов, но во-первых каждый документ в монге это десяток, а то и больше записей в рбд, а во-вторых можно добавить механизм локов выше в абстракции. Тебе и для рбд такое пригодится, чтобы не ебаться с мерджем изменений от двух разных пользователей.
>>3505497 Что вы там блять разбираете постоянно. Мне похуй что это значит вызов метода сеттера, мне важно ЧТО ПРОИСХОДИТ а не КАК. Вот серьёзно вы реально каждую строку читайте и думаете "так вот тут у нас такое условие" я просто читаю код как книжку и все.
Императивная хуйня. В нормальном DDD поведение объекта должно быть скрыто от разработчика.
Разработчику достаточно настроить событийную модель и поддержать пару пайплайнов, чтобы аналитик мог в декларативной форме описывать сценарии на ubiquitius language.
>>3506058 Функциональная шиза тоже нахуй не нужна. Писать нужно на таком уровне абстракции, чтобы разработчик ничего не знал о деталях реализации логики приложения.
В коде описывается один общий репозиторий под аггрегаты и событийная модель. Поведение настраивается через AOP c помощью XML аналитиками или в крайнем случае в коде по паттерну спецификация.
Только так можно добиться чистого кода без запахов.
Шарпоняши, какой линтер у вас тут самый строгий модный молодёжный? Хочется именно CLI тулзу чтобы и в CI запускать. И ещё, как вы форматер настраиваете, может конфигом поделитесь? А то dotnet format по дефолту чето даже длинну строки не везде энфорсит как я погляжу. Я на шарп сегодня первый раз увидел, лень искать-разбираться, просто скажите как надо пожалуйста. А то я большой любитель обмазать проект с самого начала всякими статическими анализаторами...
>>3506473 Сиаем в дотнете тоже не пользуются? Ну или вот например я хочу сказать клод коду чтобы он все замечания линтера пофиксил - если линтер это CLI тулза то клод код сам её запустит и посмотрит вывод, а если это "свой встроенный линтер" то тогда что, вручную всё копипастить?
Ну бля я не верю что в 2к25 существует такая жёсткая связность между яп и гуём для кодописания на этом яп и комьюнити неиронично это хавает, ну камон шаропняши, я знаю что вы можете лучше...
>>3506537 Нахуя мне твоя нейронка если все это делает решарпер при коммите? В студии копилот встроен который тебе целые куски кода генерирует и ошибки ищет.
Вот каким надо быть долбоебом чтобы в 2к25 консоль открывать это да.
>>3507213 > И где же шарп дискусии? Только войной с спринговыми сосальщиками тред и жив. Ещё полгода назад здесь всем было похуй на жабу и обсуждали формочки WTF и программирование на XAML > Тред блять закрепить не могут уже 2 или 3 месяц За всё время существования шарпотредов их ни разу не закрепляли.
>>3507218 >За всё время существования шарпотредов их ни разу не закрепляли. Я про то что ходить в этот тред нужно было через перекат из 60 треда с мобилы, сейчас вроде уже пофиксили, но буквально пару недель назад приходилось ходить так. >Ещё полгода назад И где?
>>3507208 >Через классы. А при чём тут обоссанная жаба, если тред про шарп?
Какие классы? А создавать как? через пару КЛАССОВ фабрик и провайдеров? Вы там совсем ёбнулись в конец?
Вот я пишу метод, и хуяк, я понимаю, что мне надо в БД посмотреть кой-чего. Как мне не переписывая мой метод НА КЛАССЫ сделать запрос в БД и не блокировать при этом поток исполния? Ну или как не переписывая мой метод НА КОЛЛБЕКИ и не связываясь с многопоточной внутрянкой это сделать?
>>3506273 >Перед тем как оправдывать монго-биби, ответь на два вопроса:
>- нахуя хранить несвязанные данные? Что ты имеешь в виду? Хранить данные в несвязаном виде? Ты про отсутствие констрейнтов?
>- нахуя хранить данные с неопределённой схемой? Схема определяется кодом слоя репозитория. Отсутствие схемы может быть и плюсом, когда ты делаешь полиморфное хранилище с однотипными но немного разными данными.
Я уже достаточно писал про плюсы монги по сравнению с реляционными бд.
>>3507466 >Как писать "Виртуальные треды, акторы, реактивщина." без коллбеков? > >Так, чтобы код можно было слева-направо читать и сверху-вниз? Мудило, думаешь если будешь изображать клована сразу станешь убедительно звучать?
>>3507473 Так он спрашивает по делу. Реактор - промисная обертка над коллбеками. Виртуальные треды - очень хорошо, но без промис говнеца мы будем писать вызывать коллбеки прямо из этих тредов. Акторы - эвентлуп который по факту те же коллбеки которые ты передаешь в сообщении.
Что не так? Я начинал программировать на коде, который до TPL был написан. Прошёл еблю с ручным управлением потоками, с самописными промисами. Работал со стилем begin/end. Ебался с реактивным кодом, я всё это видел.
Когда появился TPL - то мы резко весь код на него начали переписывать, и он тупо стал ПОНЯТЕН. Не ворох ебучих коллбеков, перемешанных с примитивами синхронизации, а просто функции, написанные слева-направо и сверху-вниз, которые могут подождать не блокируя поток.
В джаве нет async/await. И еще лет десять не будет. Джаву можно просто вычёркивать
>>3507608 Если ты такой дохуя олдфаг, ты должен помнить, что до микросервисного безумия никто не делал по 100500 асинхронных операций в коде. Просто не было необходимости, тебе IIS давал поток и ты в нем спокойно работал без асинков. Не хватает памяти - докупил плашку и снова хватает. Это сейчас жиды всех затянули в облака, где надо сделать кучу асинхронных вызовов в каждой сраной ручке. Раньше просто писали код.
>>3507469 Да, блин, это просто коллекция бзонов, чем база данных и должна быть. Окей, я один раз повторю вкратце чем монга удобнее сиквела.
1. Формат данных гораздо ближе к тому, как оно хранится в коде. Никакие орм нахуй не нужны. Чтобы понять, как данные в коде соотносятся с тем, что лежит в бд, не надо изучать кучу кода. 2. С сиквелом на каждый чих пишут новый селект, в монге у тебя в куче мест будет вызов одного и того же метода получения объекта по айди, а просто потом уже вычленение нужной информации. Плюс при дебаге для анализа информации в бд не надо писать кучу джойнов, чтобы понять, что там лежит. Релевантные данные сгруппированы большими кусками. 3. Из-за обилия бойлерплейта все кому не лень клепают кучу абстракций и паттернов типа unit of work, а потом заёбываются это всё поддерживать. С монгой это всё тоже нахер не нужно. 4. Суперфункциональная база данных приводит к тому, что кто-то умный успел понаписать кучу хранимых процедур и функций (в лучшем случае) и триггеров (в случае несколько похуже) с бизнес логикой. В итоге бизнес-логика размазана по sql и c#. Удачи сопоставлять и поддерживать это.
У меня достаточно опыта работы и с тем, и с другим, и работа с sql занимает намного больше времени и порождает намного больше багов просто в силу раздувания кода. Зато можно над одной таской три дня корпеть вместо одного. Заебись, хули.
>>3508064 Конечно. В чем проблема? Асинки нужны для экономии памяти. Память надо экономить, когда глупые и жадные кабаны пытаются выгадать копейки и запустить 20 контейнеров на одной несчастной машине. Опытные девопсы никогда так не делают, но всегда найдется мартышка с галеры. Когда у тебя один апп сервер бежит на одной машине и не хватает памяти, ты просто докупаешь память, она стоит хуйню, экономить не надо. Тогда асинки не нужны, менеджментом потоков занимается иис или томкат или апач или еще кто.
>>3508074 То есть монга для тех, кто не может в sql из-за недоразвитости участков мозга. Ну как бы это не секрет, в айти много идиотов. Все твои охуительные истории про данные лежат в одном месте работают ровно до тех пор, пока продакт не приходит с новой охуительной идеей, которая все перекраивает. В sql ты можешь джоинить кого угодно с кем угодно, в монге - хуй на, модель одна. Бонусом идет ебля с версиями записей, схемы то нет.
>>3508062 Дело вовсе не в памяти, а в том, что у тебя запрос блокирует тред. Во-первых, этот тред сидит и нопы выполняет пока ему ответ из бд придёт, тратя процессорное время. Во-вторых, тред берётся из тредпула, а их там ограниченное количество. Если пришёл запрос, а тредпул исчерпан, то запрос посылается нахуй.
И вот сначала писали всё блокирующее, потом стали коллбеки хуячить, чтобы треды немного освободить, ну а потом придумали синтаксический сахар в виде эвейтов (асинки не нужны на самом деле).
>>3508080 Давным давно ядро складывает такие ожидающие потоки отдельно и квант времени им не выдает. Никто нопы не крутит. Ты можешь запустить 1000 потоков, повесить все на один сокет, и ядро сделает балансировку нагрузки. Дело именно в памяти, под каждый тред выделяются какие-то служебные данные, а в дотнете паджиты еще и насрали от души сразу на пару мегабайт пер тред. Колбеки писали в джаваскрипте тупо потому, что там нет многопоточности. Никто не думал, что через 30 лет долбоебы будут писать бекенд на скриптовом языке, инженеры тех лет охуели бы от современного айти. С ростом популярности нодежс это говно протекло и в другие языки.
>>3508079 Ты если такой умный, пиши сразу на ассемблере, хули. Не понимаю, зачем себе проблемы придумывать. Это как долбоёбы, которые солнцезащитным кремом не мажутся, потому что "они ж не пидоры", а потом обгоревшие сидят и стонут.
Вот придёт тебе продакт с охуительной идеей, где один-ко-многим надо на много-ко-многим менять, и придётся тебе писать миграции. Точно так же никто тебе не мешает написать миграции для монги, чтобы проапдейтить все сущности. И не будет никакого версионирования.
>>3508081 У тебя что с эвейтами, что без них n потоков в пуле, это никак на памяти не отражается. Исчерпание пула называется thread pool starvation или exhaustion, и это реально существующая проблема.
>>3508082 монго уместен только для несвязанных ни с чем сущностей и когда нет транзакций и изменения схемы данных. Во всех остальных случаях лучше использовать СУБД
>>3508084 Ты не понял. Я руками на старте моего сервера могу создать 1000 тредов на любом языке, хоть на асме, и мне асинк не нужен.Будет такой себе пул на уровне ядра. 1000 тредов займут больше памяти, чем 10 тредов, но память или есть или нет. Похуй, 2гб сожрет твой сервер или 3гб, когда у тебя 4гб на машине и на все хватает. Поэтому асинки нужны для экономии памяти, других причин нет.
>>3507528 >Реактор - промисная обертка над коллбеками. Виртуальные треды - очень хорошо, но без промис говнеца мы будем писать вызывать коллбеки прямо из этих тредов. Акторы - эвентлуп который по факту те же коллбеки которые ты передаешь в сообщении. Это конкурс на самый тупой ответ, что ли? Что за хуету ты несешь?
Во первых какая разница что там внутри, если ты пишешь код который читается слева направо, с хуя на залупу. Во вторых нет там внутри никаких колбеков.
>>3508113 >код который читается слева направо, с хуя на залупу А какая разница если это всё равно коллбеки? Промисы для того и придумали чтобы сделать из коллбеков формат чтения слева направо, но от этого они коллбеками быть не перестали. >Во вторых нет там внутри никаких колбеков Где это внутри? Что ты имеешь в виду под этим словом? По твоему конструкция then(...).then(...) в реакторе это не цепочка из коллбеков? Ебобо?
>>3507608 >Когда появился TPL - то мы резко весь код на него начали переписывать, и он тупо стал ПОНЯТЕН. Не ворох ебучих коллбеков, перемешанных с примитивами синхронизации, а просто функции, написанные слева-направо и сверху-вниз, которые могут подождать не блокируя поток. У тебя просто симптом утенка. Тебе дали асинки и ты теперь считаешь, что кроме них ничего и не бывает.
>В джаве нет async/await. И еще лет десять не будет. Джаву можно просто вычёркивать У тебя какие-то комплексы, что тебе надо постоянно джаву вспоминать? Джаве не нужны асинки, там есть виртуальные треды которые делают всё то же самое, но в разы проще для разработчика.
>>3508118 >Тебе дали асинки и ты теперь считаешь, что кроме них ничего и не бывает.
Ты долбоёб? Я тебе русским языком объясняю, что я прошёл через все круги параллельного, многопоточного, асинхронного, неблокирующего, синхронизированного ада.
TPL был глотком воздуха, когда можно просто забыть про коллбек-хелл, взаимные блокировки, или никуда не ведущие промисы, можно забыть про ручное написание фоновых потоков. Не ебаться с количеством потоков, с отменой операции, с джоинами потоков
Симптома утёнка у меня нет, потому что я НЕНАВИЖУ БЛЯДЬ писать многопоточный код руками, а таски буквально решают все проблемы и позволяют сконцентрироваться на логике приложения, а не на примитивах синхронизации потоков.
>>3508826 >Уёбывай обратно в свой жабатред, здесь перекатывают после 1000. Иди на хуй, пидор, я и перекатывал тред в прошлый раз. Получилось хуёво, но картинка охуенная
Поцаны, я вышел из криокамеры. На что сейчас принято мигрировать с BinaryFormatter? - Данные мои, могу пересериализировать. - Важна секюрность и перфоманс. - Простота миграции - мне лень писать атрибуты для protobuf. Смотрю на MessagePack, вроде перфоманс ниче, но есть предупреждение про безопасность. Я не хочу чтобы мне инжектнули через какую-то форму кусок бинарного кода (я знаю что нужно писать валидаторы).
>>3509739 Все в MS это знают, поэтому ради обратной совместимости даже в WinAPI не исправляют некоторые баги, чтобы не сломались программы, которые его неправильно вызывают. Где-то даже писали, что Windows 9 не было, чтобы не сломать определение Win95/98 по наличию цифры 9 в названии.
>>3500681 >[сеттеры] позволяют частично и произвольно изменить состояние объекта Частично - ну допустим, но не произвольно - сеттер можно настроить, чтобы он присваивал только допустимые значения. Приведи хоть пример как правильно. Правильно будет когда нужно обновить свойства объекта вызывать каждый раз конструктор, который будет разрешать создавать одни только допустимые состояния этого объекта, ты такой предлагаешь подход?
1. Вызывать конструктор объекта через new запрещено почти во всех проектах.
2. Вызов сеттера это красный флаг. Он всегда означает, что инкапсуляция нарушена и ты смешиваешь домены в одну кучу.
В твоём случае объект сам инкапсулирует всю логику и сеттеров у него не может быть. Ты просто инжектишь объект и пользуешься его свойствами. Все обновления происходят автоматически по событийной модели
>>3511148 Вся эта хуйня в нынешних реалиях уже неактуальна и нежизнеспособна. Бизнесу уже давно поебать на весь этот чистый код и прочие "бест-практицес". Сейчас надо чтобы просто работало, быстро и надежно. Никто не будет ждать пока ты там свою событийную модель вкорячишь и кучу фабрик напишешь, чем быстрее твое говно выйдет в пром, тем лучше. Поэтому достаточно просто писать так, чтобы оно не падало и не жрало овердохрена ресурсов.
>>3511258 >Сейчас надо чтобы просто работало, быстро и надежно. Никто не будет ждать пока ты там свою событийную модель вкорячишь и кучу фабрик напишешь, чем быстрее твое говно выйдет в пром, тем лучше. Дада. Только проблема есть, без всего этого твой проект загнется через 2 года под весом техдолга. В бизнесе побеждает не заяц, а черепаха. Как говорится если долго сидеть на берегу можно увидеть как по реке плывёт труп врага.
>>3511268 Чел, когда срок на реализацию проекта с нуля чуть более полугода максимум (это со всем циклом тестирования, включая ФТ, НТ и ИТ). При почти полном отсутствии ТЗ, ежедневно меняющимися требованиями от безов и при никаких возможностях доработок со стороны интеграций (сраные гринскринщики)) - как-то похуй на техдолг и что там с ним будет через 2 года. Его за это время успеют уже раза 2 переписать с нуля.
>>3511258 >весь этот чистый код и прочие "бест-практицес"
Чистый код и чистая архитектура это хорошо и очень просто.
Многие не понимают этого и смешивают в кучу все "бест-практиcес", все неправильно понятые статьи с медиума и в итоге получается гексогональный доменный аспектно ориентированный пиздец, состоящий из восьми слоёв автомаппера и медиатра. В одном только DDD около 12 глубоких и сложных категорий, которые пихают в код.
Не надо так. Делайте просто, возьмите парочку архитектурных паттернов и следуйте им