>>3219323 Лучше попробовать самому написать игровой движок и 3Д рисовалку в реальном времени. Пусть даже на ЦПУ. Не понимая базы, ты будешь макакой-кнопкодавом. А там ничего сложного нет, геометрия за 9 класс.
>>3219660 А он нормально работает с абстракциями? У меня есть таблица проектов, каждый проект содержит список блоков, (точнее даже список сопоставлений блоков и проектов, где помимо блока и проекта есть еще позиция блока в проекте, но это уже мелочь) где блок абстрактный класс, у которого у меня на данный момент десяток разных наследников, каждый со своими полями. Как это все перенести в модели и обратно я не представляю.
>>3219543 Изначально такой зависимости не планировалось ну, кроме хранения Id, ибо без него хз как обновлять сущности, но начав реализовывать круды я понял, что мне придется писать тонны бойлерплейта, проверять конкретный тип блока, чтобы правильно смаппить его, держать в голове, что при добавлении блока необходио добавить новый switch case. В итоге данное решение показалось надежнее
> Изначально такой зависимости не планировалось По-хорошему, у тебя проект с логикой не должен ни от чего зависеть, нугеты не считаются. А вот проект с бд должен зависеть от логики.
>>3219710 Интерфейсы. Я почитал что ты пишешь и звучит что ты пытаешься сделать не как надо а так что бы кнопки тыкать поменьше (что обычно автоматизируется/убирается либами)
>>3219323 Наш российский UNIGINE тоже поддерживает C# и там аналог люмен завезли раньше, чем в Unreal Engine. Сперва анриал хотел выкупить его, но потом сделал свой. True story
Анончики, всех приветствую. Какой фреймворк взять для разработки небольшого кросплатформенного GUI под (Linux/Windows)? А именно Ubuntu/Win10-11. MAUI подойдет? Там столько всяких вриантов, абравиатур, я уже запутался..
>>3220160 Пока в вилларибо разбираются во всех этих левых биндингах (и проблемами чужеродного движка) - в виллабаджоуже сделали на ето.формс или авалонии и получили денежку (хоть сам ето не люблю, но факт есть факт)
>>3220168 еще раз спасибо няша. нихуя не знаю, ни сишарп, ни авалонию, но в понедельник вечером должен сдать "проект". ну и там правда все реально просто так то я на линусошиз, байтоеб, пишу на крестах в рот я эту винду, но хули на работе заставили
>>3220431 Я пару раз юзал именно query-синтаксис пока с Linq2Db работал. С ним сложные джойны и группировки пишутся быстрее и выглядят читаеемее, чем через чейнинг методов. Плюс с помощью него достаточно удобно всякие не очень сложные парсеры с помощью либы Sprache описывать https://github.com/sprache/Sprache?tab=readme-ov-file
>>3220307 Использую sql + dapper. Linq и прочий рак уровня dynamic придумали менеджеры, чтобы впарить лохам новую версию вижуал студии. Когда-то были времена, когда студия стоила денег, а сишарп был модной популярной технологией.
>>3220307 Зависит. Когда удобнее написать через квери - квери. Когда удобнее написать через экспрешн - экспрешн. Когда надо чтобы быстро - голый скуль.
>>3220900 Ну. Типа. Дополнение. Вот мне надо первый элемент найти по ид найти. Экспрешном - это будет одна строчка. Квери - это будет дохуя строчек. Берем экспрешин. Надо написать какой-то сложный жоин с группировкой и прочими хуйнями. Экспрешном - это превратится в какую-то кашу ебаную. А квери - ок смотрится, еще и не надо как еблан постоянно инклудить все. Берем квери. О. А теперь нам надо какой-то массовый апдейт сделать. Допустим, при запуске приложения - всем пользователям выставить статус оффлайн, ведь мы этот статус в БД держим зачем-то. Пользователей дохуя. Обычный скуль - за 0,000000000000000000000001мс выполнится, условно, черзе еф - ты будешь ждать запуска приложения 1000000000000000000 лет, пока все переберешь, пока всем переставишь статус. Так что берем и дергаем обычный скуль.
Вопрос по библиотекам. Можно ли как-то собрать библиотеку, чтобы она была одним .dll и в себя все зависимости включала?
Распишу в чем проблема. Вот есть у меня проект. Модульный. В базовой сборке - описаны всякие интерфейсы того как сделать свой модуль, который бы мог подключиться к основному ядру приложения, и начать работать. Есть сборка которая реализует ядро. Ядро лезет в папку {installDir}/modules и ищет dll с подмодулями, загружает их и погнали. Все так работало. Но меня, смущает, что папка в которую кладутся модули выглядит как пиздец, ведь после сборки библиотеки модуля - там лежат все .dll с зависимостями, ресурсами. Очень сильно глаз режет. Хочется чтобы было просто CompanyName.Module1.dll, ComplayName.Module2.dll. Плюс - нельзя просто сказать пользователю - удали эту .dll и подкинь вот эту. В древние времена на плюсах делал такое и на выходе был один dll на модуль. Уже не помню как эту магию делал. Давно было. А как на шарпах сейчас так же сделать - чет не представляю. Для библоитек не реботает --single-file Даже если модуль зависит только от базовой сборки где интерфейсы лежат - на выходе имеем 2 .dll с базовым проектом и модулем.
Используя Marshal.GetLastWin32Error() я получаю код ошибки, а как узнать по этому коду, что за ошибка? Например на странице метода SendInput нет списка возможных ошибок. Там пишется >This function fails when it is blocked by UIPI. Note that neither GetLastError nor the return value will indicate the failure was caused by UIPI blocking. А в чем подробность, если мне просто возвращается код?
>>3220969 Не тот фрагмент процитировал >The function returns the number of events that it successfully inserted into the keyboard or mouse input stream. If the function returns zero, the input was already blocked by another thread. To get extended error information, call GetLastError.
Здарова шарпаны! Как ваше ничего? У меня все нормально. Спасибо, что поинтересовались. А вопрос такой. У меня закрыт прямой доступ к Майкрософту, зайти на их сайта можно только через впн (так надо). Так вот, при публикации приложения если не подключимся к впн, студия может зависнуть на неопределенный срок. В процессе зависания можно завэпээниться и все нормально запаблишиться. Очевидно студия лазит на сервера мелкомягких. На кой черт она это делает? Чуть ли не каждый раз, боять. Даже когда никаких новых нугетов, никаких новых библиотек от майков не добавлялось. Что она там делает? Каждый раз все ресторит? Зочем? Можно как-то стать сильным и независимым от серверов Майкрософта?
>>3221356 Алсо, почему-то все найденные мной мапперы не утруждают себя поддержкой netstandart 2.0, так что приходится пользоваться протухшими версиями.
Ребята, у меня проблема + деменция. Проблема: проект blazor каким-то образом ебически кеширует страницы на клиенте. У меня был не дописан контроллер на сервере, вернулась 404 страница вместо джейсона и блейзор выдал ошибку и продолжает её выдавать даже после того как я пофиксил контроллер. - В постмане все нормально возвращается по тому же адресу - Очистка кэша/сессии/данных/ctrl+f5 браузера не помогает, зато помогает анонимное окно, только в нем не работает дебаг, либо фаерфокс вместо браузера в котором тоже на работает нормально дебаг - Полная очистка проекта/удаление obj/bin, ничего не дает - Коментирование UseHttpCacheHeaders/UseResponseCaching/config.CacheProfiles ничего не дает - Попытка пробить експирацию кэша вслепую (увеличил системное время на неделю вперед) тоже ничего не дает
Где-то пол года назад я уже здесь писал и тогда как-то сам и пофиксил и уже забыл чё делал, а сейчас чето головой об стену бьюсь.
>>3221696 >>3221698 Все отбой. 1) Почистил уже конкретно на запросе во вкладке network, теперь прошло нормально. 2) У меня в проекте оказывается подключен Marvin.Cache который дает такую шляпу, только опять же по какой-то причине мне не выдает этот пакет в нугете. Нужно его будет когда-то его доковырять вероятно никогда
У linq2db есть аналог ApplyConfigurationsFromAssembly и IEntityTypeConfiguration<T> из EF? Хочу разделить конфиг сущностей по файлам, чтобы не лепить портянку на 1к строк в одном файле.
Сап. Наговнокодил я вот такой код, как на картинке. Нужен был, чтобы в IEntityTypeConfiguration имена колонкам задавать с нижнем подчёркиванием, но это не суть. Как так вышло, что данный кусок кода вызывает утечку памяти? Я уже написал нормальный метод, который делает то, что надо, но, блять, как? Объясните, пожалуйста, ибо я что-то туплю. Жрёт всю память, что есть в доступе, а потом выдаёт ошибку.
>>3221939 Какая разница? Пробую новый инструмент, но документация у linq2db ужасная. Сайт фиг знает сколько лет не обновляли.
>>3221937 Проблема с конфигурацией оказалась лишь началом.
Есть ли какой-то автомаппинг колонок бд из snake_case в CamelCase для ДТО-шек? Аля DefaultTypeMap.MatchNamesWithUnderscores = true из даппера. Засорять запрос "as НазваниеКамелКасе" не хочется. https://pastebin.com/Zkm7GxZT
>>3221937 >У linq2db есть аналог ApplyConfigurationsFromAssembly и IEntityTypeConfiguration<T> из EF? >Хочу разделить конфиг сущностей по файлам, чтобы не лепить портянку на 1к строк в одном файле. >>3222503 >кодил я вот такой код, как на картинке. Нужен был, чтобы в IEntityTypeConfiguration имена колонкам задавать с нижнем подчёркиванием, но это не суть. >>3222637 >Проблема с конфигурацией оказалась лишь началом. >Есть ли какой-то автомаппинг колонок бд из snake_case в CamelCase для ДТО-шек? Аля
А, казалось бы, возьми EF и не мучайся. Но нет, пацаны же сказли, что EF тормозной и сложный, а даппер простой и быстрый - буду страдать.
>>3222835 Ну мб людям надо. Как то нужно было загрузить в bd очень дохуя инфы, и писал я прилку на заказ которая это сделает. И вот EF работал раз в 10 медленнее чем даппер, и вот получалось 3 дня и 30 дней загрузки. Был резон юзать даппер. А в случае дрочбы на нано секунды то да это нахуй.
>>3222866 >И вот EF работал раз в 10 медленнее чем даппер, и вот получалось 3 дня и 30 дней загрузки. Был резон юзать даппер. 1) В том и прикоол, что когда надо быстро-здесь-и-сейчас, берут даппер и не страдают дрочевом с паммингом, конфигурациями и т.д. потому что в какой-то момент всегда получается, что ты ради "удобства", просто пишешь свой аналог EF поверх даппера. 2) EF сейчас уже настолько наоптимизировали, что большинство случаев когда "медленно", обычно означает - хуевое проектирование 3) EF так же умеет во встройки, чистый sql и вот это все при необходимости, когда надо грязно и быстро. 4) Для особых ценителей, можно вообще использовать их одновременно, чтобы там где надо "удобно" юзать ef, а где "быстро" - даппер.
>>3222866 Еф уже давно не только еф но и база которую расширяют специфичными для конкретных субд аддонами оставляя еф как прослойку которая знает как классы мапятся на схему бд. Из последнего что юзал это аддон на инсерт ... он конфликт ду ... и булк инсерт когда нужно было залить пару десятков кк записей. Но юзая подобные плагины нужно читать доку т.к. большая их часть работает в обход чендж детектора (что очевидно).
Я лично топлю за еф в первую очередь потому что он выступает единой точкой правды (классы+конфиги) и даёт удобные миграции из коробки. А за счёт чендж детектора можно иногда очень даже разгрузить бд/не писать бойлерплейт.
Если даже есть то что ну никак не получается решить кодом то всегда можно из того же дбконтекста вытащить коннект и юзнуть даппер
Даппер к слову тоже может говна подкинуть (вернее сам себе, но это лирика). На новой работе досталось в наследство 30-40 микросервисов которые как то нахуеверчены на даппере и запросы там собираются склейкой строк (пиздец). Каждый такой запрос получается уникальным и оседает в кэше даппера. Смотришь на дамп памяти сервиса а там 800мб чистого SQL текстом в куче
>>3222928 >ровно как и чекать миграции Ага, главное руками в них не лезть. Часто попадаются любители, когда в миграции что-то не так, просто нахуевертить руками исправления в миграции, т.к. мозгов сделать это правильно через код не хватает. Всегда на ревью такую хуйню заворачиваю, пока мне не докажут невозможность сделать миграцию нормально без ручных правок. Никто еще не доказал.
>>3222931 у меня даппер почему то пропускал id некоторый. Пример, добавляю новые записи, их 1кк, в бд последняя запись с id 1 200 000. Но записей всего 1кк как и должно быть. Ебенит типо 1-200 потом 280-500 пропустил 80 id и пошёл дальше, и все время одни и теже пропускал. Хуй знает почему.
>>3222958 Хз. Я порой добавляю всякие грант пермишшенс и делит данных. Пару раз патчил что бы вместо ренейма был делит+адд. В целом соглашусь что править их плохо, а тем более мержить, шанс что потом другой разраб набьёт ебало когда снапшот пойдёт в рассинхрон с миграциями слишком велик
>>3222964 >Я порой добавляю всякие грант пермишшенс и делит данных. Это все можно провернуть через конфигурацию. И даже в суперсложном случае, где надо задействовать, что-то, чего EF не умеет и прописать это через чистый SQL, это проще делать через конфигурацию, чем встраивать в автогенеренный файл. >>3222964 >и делит данных Если речь идет о сидированных данных, и это изначально делать нормально, через .HasData, то и удаляется это тоже таким же способом. Если же речь об удалении обычных данных, то это не область ответственности миграций. >>3222964 >Пару раз патчил что бы вместо ренейма был делит+адд. Такое можно делать через две миграции подряд. Сначала в конфигурации лепится на измененный объект игнор, генерится миграция на удаление. Потом игнор убирается и генерится вторая миграция.
Плюс такого подхода, что все миграции можно в любой момент снести и сгенерить одну новую единую (например при переходе на новую БД) и она будет содержать конечный результат идентичный старому набору миграций, без всяких ручных правок.
Всем привет. Помогите, пожалуйста разобраться с маппингом в Dapper'e. Есть вот такой запрос https://pastebin.com/VU0W9Gxw Как тут смапить к GetTransportationRequestResponse?
потому что задумка такая "если первое значение нулл, значит вероятно весь объект нулл и нечего его конструировать" А вот решения "ты мне тут не гадай, а собери объект" нету. Есть пуллреквест на "а давай делить по полю которого нет в модели", но толку то.
Как в ef core загрузить объект вместе со всеми связанными классами, если в нем есть список с абстрактным классом? Для каждого возможного типа прописывать свою логику инклюдов?
>>3224558 > Не нужно учить "еще один метаязык" в котором хрен поймешь как выразить нужное и при этом чтобы оно было эффективным. Ну как не нужно, нужно учить sql. Я вот использую ef core уже лет эдак 5, из sql зная только select from и where.
>>3225885 Не видел такого. Вернее видел, но у мауи. Comet называется. Я конечно одобряю, но все же это все еще очень очень очень сыро. Даже примеров толковых нет
Хоть одна причина, почему залупа на даппере не может вставить в sql строку параметр сортировки, когда всё остальное нормально вставляется. Да даже через ебаный реплейс запрос рабочим получается. sortOrder - строка. Если руками параметр написать в sql строку, то тоже работает. Сама ощибка: Npgsql.PostgresException (0x80004005): 42601: syntax error at or near "$2". Что я делаю не так? Запрос рабочий.
>>3226633 А ты вообще уверен что эта часть в запросе у постгреса параметризуремая? Что то мне говорит что нет. Та же ситуация когда в запросе нужно заменять in на any
Таки да. "Note that PostgreSQL does not support parameters in arbitrary locations - you can only parameterize data values" Спасибо, что наставили на путь истинный.
Здравствуйте, решил вкатиться и столкнулся с проблемой. Я никак не могу выкупить, зачем нужны интерфейсы? Что они могут делать такого, чего не может абстрактный класс?
Разумеется, я знаю, что класс может унаследовать один класс и реализовать множество интерфейсов, но ведь если мы разрешим множественное наследование, то получится, что абстрактный класс содержит весь функционал интерфейса: - Реализация объявленных методов - Реализация методов по умолчанию (с c#8.0+) - Реализация свойств
Я встречал разные моменты по типу: >Интерфейсы формируют интерфейс взаимодействия у классов. Так ведь при помощи наследования классов наследуются публичные поля и методы, тем самым тоже наследуется интерфейс взаимодействия классов.
Я глубоко не вникал, но у меня есть подозрение, что они как-то по разному в промежуточном коде выглядят, неспроста же у интерфейсов конструктов нет. Но я этот код в глаза не видел, к сожалению.
В общем, подскажите, пожалуйста, зачем нужны интерфейсы и где они справляются со своей задачей лучше, чем абстрактные классы
>>3226839 > Что они могут делать такого, чего не может абстрактный класс В шарпе - нет множественного наследования. В твоем коде - тебе может быть интересно, что у класса должен быть метод с такой сигнатурой, а из какой он иерархии - тебе до пизды.
Сверху, довольно долго интерфейс в шарпе - не содержал логики и было заебись.
> , но ведь если мы разрешим множественное наследование, то получится Проблема ромба получается. Два класса - наследуются от одного базового, потом третий класс - от обоих наследуется - пизда, нахуй, треш-угар-садомия, трудноуловимые баги и прочий ужас.
> что абстрактный класс содержит весь функционал интерфейса Да. В плюсах так и делают. Проблема абстрактного класса как раз в том, что в нем может быть сокрыто дохуя и больше логики, дополнительно - уже сказал, проблема ромба: class A { abstract void foo();} class B : A { override void foo() => Console.WriteLine("B")} class C : A { override void foo() => Console.WriteLine("C")} class D : B, C { }
Я создал инстанс D - что должно вывестись при вызове метода foo()? Хуй его знает на самом деле. А если я скастю к B? А к C? А к А? Короче хуйня выходит в любом случае. Вот чтобы о такой хуйне не думать - все нормальные языки - запретили эту хуйню с множественным наследованием. НО нам все еще нужен механизм, который позволит описать как куски программы могут ОБЩАТЬСЯ друг с другом на уровне четкого контракта.
>>3226850 Я понимаю проблему ромба, но ведь её порождают и интерфейсы в c#8.0+ где есть реализация по умолчанию.
Если откреститься от реализации в интерфейсах, то получается что абстрактные классы имеют реализацию, но были лишены множественного наследования, чтобы эта реализация не сломалась?
Вот есть список обьектов, их последовательность обязательно нужно сохранить Но когда добавляю через AddAsync каждый перебором, а потом SaveChanges жму - они добавляются в рандомном порядке
Вижу решение жать после каждого добавления сохранение изменений, но разве нет другого варианта? (Ну еще нумерацию внутри обьекта сделать, но тоже гемор)
Например в этом видео автор создаёт интерфейс IEngine. Я бы на интуитивном уровне подумал, что тут нужен абстрактный класс, а не интерфейс, потому что до этого в уроках было что-то типа IMoveable и я подумал, что интерфейсы типа для действий нужны, но тут мои додумки ломают
>>3226874 Автоинкрементные столбцы по факту ничего тебе не обещают кроме того что ты не получишь две одинаковых цифры. Те же сиквенсы игнорируют транзакции и соответственно роллбэк. Если тебе нужно сортировать столбцы то НИКОГДА не делай это по иду если он автоинкрементный. Из последних приколов которые позволяют генерировать псевдослучайные идентификаторы по которым можно сортировать по времени это uuid v7
>>3226876 Интерфейс просто более гибкий вариант. Создавая абстрактный класс ты лишаешься возможности легко вписать уже существующую логику в новую. К примеру создаешь ты игру, условную веселую ферму, создал иерархию классов животных - Animal -> Horse. А в новой версии захотел добавить транспорт. Если Engine будет абстрактным классом, то его никак не добавить к лошади, а вот если он будет интерфейсом, то получится без проблем его реализовать - Horse : Animal, IEngine. Вообще, тут стоит руководствоваться следующими соображениями - если есть много логики, которая будет повторятся, то надо вынести ее в абстрактный класс, если же такой логики будет минимум и нужно обеспечить общий функционал, то лучше делать интерфейс.
>>3226868 Нахер они добавили реализацию в интерфейсы. Бред какой-то. Может хотят убить абстрактные классы, потому что сейчас в них вообще нет никакого смысла.
>>3226968 Бессмысленная хуйня, учитывая, что без доступа к приватным полям едва ли получится реализовать что-то осмысленное. Лучше бы тогда добавили какое-нибудь ключевое слово для методов, чтобы этот метод можно было не реализовывать, а при вызове он бы кидал исключение not implemented. К слову метод можно также добавить написав обычный экстеншн.
>>3226931 Потому что бывают случаи, когда какой-то метод тривиален и у всех будет одинаково реализован. Если мы опять же вводим абстрактный класс, то получается, что все должны от него наследоваться, а в контексте того что наследоваться в шарпе можно только от одного родителя - усложнение иерархии, которое нахуй не нужно-то.
До этого приходилось костылять сбоку методы расширения для таких вот целей, но это костыль и вообще, когда ты обязан для работы с каким-то интерфейсом постоянно что-то из расширений тянуть - почему это не сразу в интерфейсе.
Ну типа, ну лол. Вот у тебя какой-то класс логгера. Есть метод Log, который принимает уровень, паттерн и прочее. Очевидно, что сделает каждый - напишет по методу расширения: LogError, LogWarning, etc. Но с расширениями - теперь надо будет еще какой-нибудь using Suka.Pizda.Zalupa.Logger.Extension не забывать подключать постоянно как еблан, или выносить его в глобальные юзинги, в любом случае - кал выходил. А так - оно сразу в интерфейсе просто уменьшает число аргументов метода Log.
Абстрактные классы никто убивать не хочет и не собирается. Они все так же нужны. Какой-нибудь фреймворк ты без этого - хуй напишешь нормально.
>>3227052 Да ничего умного там нет. Это просто отдельный тип списков, у которого свои особенности, например позволяют получать или извлекать данные из других потоков. С обычными списками такое не прокатит, потому что если так совпадет, что два потока одновременно обратятся к обычному списку, то выскочит ошибка.
Есть дополнительные специфические особенности. Например очередь Queue устроена таким образом, что элемент добавляется только в конец списка, а извлекаться может только с начала. Получается типичная схема очереди, типа "кто первый подошел, того первым и обслужили". С обычными списками такой подход геморно реализовать.
>>3227111 Я только в случае моделей сущностей из бд использую. Типа базовый класс с Id и подобное. Для всех остальных случаев есть композиция и полиморфизм через дженерики.
женщина и мужчина наследники класса человек. и в класс человеков можно вынести что есть руки ноги, дышать, спать. То есть абстрактный класс дает и общий контракт и общую реализацию.
А вот интерфейс семантически подчеркивает какой то аспект. Например IМожетДышать или IСонька Тут аспект на конкретно этом, и как бы уже неважно человек там или камень. Таким образом может быть куча интерфейсов, каждый из которых описывает свой аспект.
Конечно интерфейс может описать всё и использоваться вместо абстрактного класса. Тут ведь сколько человеков, столько и мнений одни скажут что "ууу нарушается буковка I в SOLID". другие скажут - "это контракт и ниипет, идите лесом".
Так что будет тебя склонять в сторону использования только интерфейсов пока не понадобится общая реализация, на которую интерфейс просто не способен.
>>3226839 У тебя неправильный вопрос. Правильный - зачем нужны абстрактные классы, когда есть интерфейсы. Ответ - нахуй не нужны, это древнее легаси из темных времен, когда все дрочили на инкапсуляцию наследование полиморфизм, хуярили абстрактные фабрики и мартин высирал свои книжки по кд. Сейчас используют анемик сервисы, никто не пишет развесистые иерархии наследования.
>>3226839 >но ведь если мы разрешим множественное наследование, то код утонет в говне, в общем для этого и сделали интерфейсы чтобы одно изменение какого то родителя не ломало нахуй всё и ты это говно потом лопатой дня три разгребал. >Я никак не могу выкупить, зачем нужны интерфейсы? Что они могут делать такого, чего не может абстрактный класс? контракт, чтобы классы реализовывали одинаковое поведение и не были ограничены одним классом как в наследовании. > зачем нужны интерфейсы и где они справляются со своей задачей лучше, чем абстрактные классы большая гибкость чем у абстракций, интерфейсов можно нацеплять много. >>3226931 >Нахер они добавили реализацию в интерфейсы. чтоб бойлерплейты не писать
>>3227257 >женщина и мужчина наследники класса человек. и в класс человеков можно вынести что есть руки ноги, дышать, спать. То есть абстрактный класс дает и общий контракт и общую реализацию. Я как в 2000 попал. Тогда и давали все эти убогие примеры типа класс человек, наследники студент, препод и методы пойти на пару и пойти в столовую.
Не надо так писать, все уже давно убедились в том, что это нормально не работает. Надо делать классы-данные, Plain old CLR object с данными и без логики, и классы-сервисы с логикой, но без состояния. Тогда никакое наследование не нужно, абстрактные классы тоже не нужны, общий код для двух реализаций одного интерфейса просто выносится в отдельный класс-сервис и подключается в виде зависимости. Такой код проще менять и тестировать.
>>3227357 ты щас пытаешься породить древний срачь adm vs rdm. на адм у тебя как сопля размазана везде, для небольшого проекта это плюс так как каждое говно лежит в своей урне, но как только проект растёт растут и сопли и бегать собирать их по огромной кодовой базе занятие для мазохистов на рдм говне все это лежит в одной куче которую осмысляешь как буддисты дзен, но хотя бы в одном месте. >Я как в 2000 попал этим паттернам анемик и рич уже тоже лет по 15
>>3227357 да хоть в какие попадай. Концепция ООП старше тебя и за эти годы в общем то осталась какой и была.
И если у тебя что то там не работает - ну значит у тебя лапки А свое неумение использовать парадигмы на всех проецировать не стоит. Смекаешь?
>Надо делать классы-данные, Plain old CLR object с данными и без логики, и классы-сервисы с логикой, но без состояния. яскозал? Выбор того или иного - ЗАВИСИТ!!! Видимо ты всю жизнь писал один продукт и жизни за его пределами не видел.
>>3227376 >да хоть в какие попадай. Концепция ООП старше тебя и за эти годы в общем то осталась какой и была. Это не так.
>И если у тебя что то там не работает - ну значит у тебя лапки >А свое неумение использовать парадигмы на всех проецировать не стоит. Смекаешь? Чем сложнее граф зависимостей -- тем сложнее что-то менять. А менять что-то приходится постоянно. Для этого придумали IOC, чтобы зависимости были деревом, а не хуй пойми какой мешаниной. Как следствие, в листьях у тебя должно быть что-то максимально тупое с минимумом логики и без каких-то других зависимостей. ПОКО в это прекрасно ложатся.
>>Надо делать классы-данные, Plain old CLR object с данными и без логики, и классы-сервисы с логикой, но без состояния. >яскозал? Выбор того или иного - ЗАВИСИТ!!! Ну дали тебе екстеншен методы, можешь ими пользоваться, разрешаю. >Видимо ты всю жизнь писал один продукт и жизни за его пределами не видел. Сейчас одиннадцатый пишу. Некоторые, в которые глубоко не залезал, я считать не стал. Посчитал только те, в которых я оказал значительное влияние на дизайн кода. Я старый, мне под сорокет уже. Я много чего видел, и в том числе адский говнокодище, который получается, если не устанавливать себе строгие ограничения в стиле.
>>3228406 В моей хохлосрани (Киев) одна вакансия и та фейк, и шо? Ты живешь в свободной стране, тебя никто не остановит на блокпосту и не упакует потужно в бусик. Просто берешь и переезжаешь туда, где вакансий не три, а триста. Винформс - это тупик, ими можно заниматься, когда тебе за сорок, айти доебало в принципе и уже похуй, что и на чем писать. Вкатывайся в клауды, аспнеткоре серверлес кап теорема вот это все, а не пытайся ковырять окаменевший кал на винформс.
>>3228406 Ну так целься сразу на удалёнку в какую-нибудь Московскую/Питерскую контору. Тем более ты в том же UTC+3, что и Москва. Винформы, да и вообще десктоп разработка (WPF, Авалония) это смерть, гроб, кладбище для 50-тилетних скуфов, просиживающих штаны в госконторах и НИИ-ах.
>>3228485 про десктоп не совсем верно. Просто он нужен для написания чего то внутреннего. И это далеко не только госконторы и нии. И далеко не всегда древний фреймворк.
>>3228355 >Это не так. ты про фишки в виде автореализации в интерфейсах которые по факту причуда одного языка?
>в листьях у тебя должно быть что-то максимально тупое с минимумом логики Кому должно? С IoC действительно проще (удобный паттерн), но описанной тобой проблемы сложности нет. Проблема сложности это когда ты напихиваешь кучу всего и нарушаешь DRY, KISS, SOLID и еще кучу аббревиатур. Только причем тут вообще ооп. ООП это про базовое структурирование кода - классы, методы, взаимодействие и прочее, а детали "где как насрать" уже на тебе
>Ну дали тебе екстеншен методы, можешь ими пользоваться, разрешаю. спасибо за разрешение. только вот ектеншен методы несколько другое. В частности интерфейс ничего про них не знает. А значит они и не являются переопределяемой реализацией (что базово для ооп). Так что эти методы хороши, но по факту DSL, а не ООП
>Сейчас одиннадцатый пишу. 11 проект одного типа? ну такое себе. И это только на шарпе? ну тоже такое себе. Я изучал с десяток языков (а в каждом свои парадигмы) и под что только не писал (причем всегда у меня за правило "не тащить в чужой монастырь свои привычки". К чему это я? - не быть категоричным "я знаю все"
>если не устанавливать себе строгие ограничения в стиле. для этого и придумали паттерны (не те, которые GoF), а вообще про дизайн...чтобы структурировать. Только причем тут "нам нужен абстрактный класс или интерфейс" - выбор этого определяется правилом "я конечно люблю интерфейсы, но с ними получается лютое говно в данной задаче"
Считаю что WinForm или типа Qt - самое лучшее для вката. Писать десктопные проги намного интереснее чем веб. И главное все наглядно и понятно, в отличие от веб-фреймов где под капотом что то делается и выдается результат. По мне так можно потренить на десктопе хотя бы первый месяц, может затянуть кстати.
>>3228570 >> про десктоп не совсем верно. Просто он нужен для написания чего то внутреннего. В нескольких местах, где работал, как раз занимался тем, что внутренние штуки для автоматизации бизнеса переделывал с десктопных апп на современные, модные, молодежные веб-приложения. Новые десктопные приложения там запиливать не хотели. Так что скажу так, есть существенная тенденция к отмиранию десктопных приложений. Из того что знаю, та область, где десктопные аппы плотно сидят и умирать не собираются - это различный внутренний инженерный софт. Но ради него, да, формы или WPF учить явно не стоит. Там банально для трудоустройства будут скорее всего будут требовать вышку. Причем скорее всего не айтишную, а инженерную, по профилю работы компании или смежную с ней.
в статусе вкатуна уже некоторое время задрочил по десять раз метанит, рихтера, sql и возник вопрос чё дальше то учить в мок собесах спрашивают исключительно синтаксис и базу по .net, в вакансиях то просто "знание C# и SQL" то сверху HTML JS TS ASP.NET CORE - мягко говоря дохуя информации пока для себя наметил только выучить SOLID, EF Core, поковырять git
в общем анончики подскажите в каком направлении двигаться а то нихуя нет представления даже какие пет проекты можно с текущими знаниями делать
>>3228851 > HTML JS TS ASP.NET CORE Вот это и учи, плюс реакт. Тайпскрипт можно пока пропустить. Еще нужно знать докер, CI/CD, гит обязательно. Базовые навыки пердолинга консольки не помешают.
>>3228723 Не, нихуя. Веб интереснее хотя бы потому, что есть миллион готовых примеров, интересных библиотек с разными контролами, и в целом очень легко найти информацию по любому вопросу. Плюс css куда гибче и выразительнее xaml. До сих пор помню эти лесницы из десятков вложенностей, с необходимостью повторять имя родителя при задании свойства.
>>3229007 Чел. Подумой! Это же целых 9 часов! ДЕВЯТЬ! За эти 9 часов - ты можешь! Ты можешь... Хуй знает что ты можешь.
По сакутину и его материалам. Там все оч поверхностно. Типа новичку - ок. Кто хотя бы 100к строк написал - там вода и не очень смешные шутки.
Короче. Вот тебе задание. Берешь VisualStudio, открываешь, создаешь новое коносльное приложение и делаешь программу по этим требованиям: - текстовый редактор - с подсветкой синтаксиса(сисярп хотя бы из коробки) - файлы могут быть большими(больше 4 гигов один файл) - поддерживает автоопределение кодировки - может в undo-redo - поддерживает плагины - поддерживает поиск как конкретного слова-словосочетания, так и нечеткий поиск - может в автосохранение и автовосстановление при непредвиденном закрытии приложения - автоматическое обновление, без потери обратной совместимости Вот пока будешь это делать - гуглишь что непонятно. Смотришь видосики, читаешь книги. Как угодно получаешь информацию. Как только у тебя будет хотя бы демка, возвращаешься к этому видосику - смотришь. Если что-то новое узнаешь - ставишь лойс, если не узнаешь - ставишь дизлойс.
>>3229305 Как то беспонтово. Можно парсить весь двач, тянуть все аттачменты, прикрутить несколько нейронок по детекту нсфв и ненормативной лексики, загрузить все посты куда нибудь в эластик и на всей этой инфе строить прогнозы популярности того или иного треда (из уже агрегированного есть счётчики популярности которые считает сам двач, количество просмотров, постов, уникальных постеров). На основе того что лежит в эластике можно ещё какие то закономерности и прогнозы посчитать. Тут тебе: - кор сервис - постгрес - еф - эластик - кафка/рабит (при желании) - графана - s3 - биг дата (?) - хайлоад (???) Прикрутив симпатичный гуй, а не графану можно ещё и фронт захватить: - асп - аутентификация+авторизация - веб - домены - ссл (лестэнкрипт) - нжинкс Так же желательно пройтись по всем граблям обсервабилити - трейсинг - метрики - хелсчеки Очевидно что если есть всё что выше то нужен и нормальный ci/cd - гитлаб/гитхаб сборка - oci - джокер/кубы - деплой Имхо джентельменский набор бэкендера
По началу можно накидать буквально всё под пивас, но после охвата пачки досок и накопления нескольких кк постов будут то там то сям вылезать дыры. Как минимум это будет что то интересное, уникальное пожалуй, а не очередной мертворождённый редактор который будет хуже всех остальных
>>3229342 1. Все это охуеть как скучно. 2. К программированию относится ровно никак, потому что ты просто предлагаешь взять пачку готовых хуевин запустить их разом и смотреть какой мы охуенный конфигуратор-скриптов.
Есть ли где то хороший текст что можно писать в контроллерах, а что нет? А то у меня пока контроллер просит пересылает данные в сервис и из него отдает обратно. Если какая то ошибка случается в сервисе, то мидлварь его перехватывает и возвращает нужный ерор клиент. Как сделать заебись?
>>3229368 Ничего лучше не писать в контроллерах. Контроллер пришел из MVC, когда пытались делать по образу-подобию десктопных приложений(на десктопе тогда потихоньку от классических: накидай на форму кнопок, прибей обработчики и погнали - как раз постепенно переходил к MVC, и все что не база - было в контроллере). Но если уж осталось. Все что касается HTTP - можно делать в контроллере - остальное в сервисе.
Ошибки связанные с бизнес-логикой - тоже лучше в сервисе формировать. Мидлварем только непредвиденные в духе - все пиздец, все упало, не могу обработать.
Короче. Воспринимай контроллер - как точку входа в приложение. Запрос до сюда дошел, значит базово он удовлетворяет тому что должно быть обработано приложением, все остальное - уже на прикладном уровне обрабатываешь, собираешь. Потом - контроллере - результат отдает.
>>3229386 Ну значит я все правильно плюс минус делал. По поводу ошибок, немного не понял, вот клиент присылает мне неправильный пароль то я кидаю условно throw new appuservalidationerror, и мидлварь перехватывает ошибку и возвращает нужную инфу юзеру где он проебалсся. Это нормальный подход?
>>3229368 У контроллера две задачи: валидировать вход и логировать выход. На вход в твою апишку могут приехать любые данные от хакера, твоя задача их проверить на инжекшены-хуекшены и отвалиться с ошибкой. Может приехать невалидный токен, которого нет в белом списке, это тоже ошибка. Бизнес логика может бросить эксепшен, его надо поймать, залогировать и вернуть пользователю ошибку 500. Это задачи для контроллера. В дотнете все это уже реализовано под капотом, ты просто расставляешь аттрибуты. Поэтому в дотнете в контроллере ты просто пробрасываешь данные в сервис, литерали метод из одной строки.
>>3229417 >По поводу ошибок, немного не понял Берешь и возвращаешь нормальный объект ошибки, который как тебе надо сериализуется. Как сделать? Либо Eiter, либо какой-нибудь Result<T>, либо ErrorOr<T> как больше нравится.
> Это нормальный подход? То что ты кидаешь эксепшины - это самый распространенный подход.
Минус его в том, что у тебя ломается нормальный флоу. У тебя смешиваются в одном месте и реальные исключительные ситуации(место на диске закончилось), и бизнес-ответы. Результат такого вот подхода: - ебатория если надо метрики смотреть. Так бы, если реальные ексепшины были, ты просто видел бы в логе сразу пиздец, место кончается, но ты должен будешь охуеть сколько всего настроить, чтобы то же самое видеть - ебатория с тем, чтобы понять где и почему что-то происходит - логика прикладного протокола между клиентом и сервером намотана кишками на мидлварь - проблемы с перформансом, потому что исключение - это не дешевое удовольствие, это сразу хуяк по перформансу
Делал бы нормально, пользуя нормальные подходы, все было бы сильно и проще и красивше и удобнее. Бизнес правила обрабатываются там где должны, перформанс не страдает, а следить за пиздецом на сервере было бы проще.
> Поэтому в дотнете в контроллере ты просто пробрасываешь данные в сервис, литерали метод из одной строки. Как минимум то, что при использовании FluentValidation валидировать придётся в ручную (из документации). Пакет FluentValidation.AspNetCore признан устаревшим.
Хм. А как собирать код без использования этих csproj файлов? Вот в си-плюсах я могу просто `gcc src/*.cpp -o bin/app.exe -Iinclude -Llib` сделать и оно само собирется, слинкуется, выдаст файл исполняемый, и никаких csproj и прочего не надо. Раньше, помню был csc, неудобный, но тоже что-то подобное позволял делать, если однофайловый проект пишешь - было ок. Но сейчас - хз чем там собирать, если я хочу под линукс, но однофайловый проект сделать.
>>3219323 >Можно ли делать игры? >>3219949 >ну, движок начинался как игровой, но у нас энтерпрайз, рендер бесконечных карт по фоткам, гео координаты, бизнес моделирование @ >А ЧО ИГРЫ ТАРМАЗЯТ ГРАФИКА МЫЛО В 640Р А ТРЕБОВАНИЯ РАСТУТ!!
>>3233424 Ну, Oil rush - не тормозил в момент выхода на ноутбучном железе. Ноутбук был что-то в духе: ноутбучный I3, 4 гига оперативки и дискретка от амуде, Win 7, 1366x768. Я не особо графодрочер, но тогда графон казался пиздатым вполне.
>>3233424 Да не сказать что мыло. Как художник, могу сказать, что можно добиться тех же результатов, что и на анриале и без просадки в производительности. Проблема с этим движком в том, что практически все придется изобретать заново, что в анриале идет из коробки. Даже наличие С# по факту не облегчит жизнь. Проще выучить С++, чем восстанавливать базовый функционал на C#.
>>3233496 А чего там нет-то? Движок довольно давно существует и некоторые фишки, которые в анриале только появились - там уже давно были.
Его проблема как я понимаю была в основном в том, что в руководстве не знали куда его пристроить, и метались из стороны в сторону, выпилив в определенный момент поддержку мобилок, и переориентировавшись на производства и симуляции, плюс - закрытость всего этого дела.
Типа, до того как анрил стал бесплатным для мелких проектов - он тоже не то чтобы прям охуеть как популярен был за пределами AAA, все либо свои движки пилили. Ну, потом еще юнька появилась открытая, и многие на ней пилили. А вспомнить конец нулевых, начало 10х, всякие индюки и мелкие конторы - либо свое делали, либо на каком-нибудь флеше накидывали прототип, чтобы собрать какой-то фидбек, а дальше - как пойдет.
Посоветуйте курс по C# на сайте coursehunter.net не для новичков, чтобы освоить C# и технологии, необходимые для разработки корпоративных приложений, быстро. Вкатываюсь, имея 4 года коммерческого опыта на джаве.
По поводу наполнения контроллеров. Контроллер делигирует работу сервису, значит ли это, что сигнатура метода контроллера и сервиса будет одинаковой? И соответственно все модели реквестов и валидаторы будут в слое Application? Или же у контроллеров свой реквест, а у сервиса другой и, соответственно, разные модели?
Если в приложении доменная модель и модель персистентности (бд) разные, то каким образом выстраивается взаимодействие?
Поправьте меня, если где не прав:
В доменном слое объявляется репозиторий, который использует доменные сущности. В инфраструктурном слое объявляются модели бд и реализуется данный репозиторий, в котором происходит: 1. Получение модели бд (DAO) через EF 2. Маппинг модели бд в доменную модель
Интерфейсы сервисов Application уровня должны находиться в Domain слое или Application слое? И зачем закрывать сервис за интерфейсом с одной реализацией?
>>3234628 >Интерфейсы сервисов Application уровня должны находиться в Domain слое или Application слое? У меня кстати недавно спор был с архитектором на эту тему. Только мы спорили насчет Domain и Contracts >>3234628 >И зачем закрывать сервис за интерфейсом с одной реализацией? Завтра тебе понадобиться подсунуть другую реализацию, а послезавтра еще и переключаться между ними. Либо перенести эту реализацию куда-нибудь в другой модуль/проект. Сравни количество ебли с интерфейсом и без. И это типовые задачи, которые возникают постоянно.
>>3234831 > Завтра тебе понадобиться подсунуть другую реализацию, а послезавтра еще и переключаться между ними. Ни разу не возникало такой необходимости. И сомневаюсь, что она вообще у кого-то итт возникала.
>>3234831 >У меня кстати недавно спор был с архитектором на эту тему. Чел, архитектор - это продажник, его задача красиво напиздеть и впарить заказчику допуслуги. Спорить с таким - это как спорить с продаваном в салоне мобилок.
>>3234936 Чтобы LSP не сломать. При наследовании, в классе-наследнике нельзя усиливать предусловия (делать параметры более конкретных типов) и ослаблять постусловия (делать возвращаемые значения более общих типов).
Если ты из метода будешь возвращать строку вместо объекта (object), то для кода, который этот метод вызывал (особенно если не напрямую, а через ссылку на родительский класс) ничего не поменяется, т.к. string наследует object'у. Если ты начнёшь в качестве параметра требовать более конкретный тип (string вместо object'а), то гипотетически, если бы такое собиралось, тебе бы в этот метод через вызов метода после приведения ссылки к типу родительского класс могли бы объект какой-нибудь другого типа запихать. И вот тут уже хз как эту ситуацию разруливать, т.к. конфликт типов.
Подумай, как должен работать этот и что он должен вывести, если бы то, что ты хочешь, можно было бы делать.
class A { public virtual void Test(object value) => Console.WriteLine(value); }
class B : A { public override void Test(string value) => Console.WriteLine(value.Trim()); }
B b = new B(); A a = b; a.Test(new { huy = "tebe" }); // Что должно тут произойти?
Ещё можешь над вот этим помедитировать
class Param1 {} class Param2 : Param1 {} class Param3 : Param2 {}
class A { public virtual void Test(Param2 value) => Console.WriteLine($"Param2 {value}"); public virtual void Test(Param1 value) => Console.WriteLine($"Param1 {value}"); public virtual void Test(object value) => Console.WriteLine($"object {value}"); }
class B : A { public override void Test(Param3 value) => Console.WriteLine($"Param3 {value}"); // Какой из методов мы сейчас переопределили? }
Типы аргументов - часть сигнатуры метода. По ней компилятор определяет, какой конкретно код нужно вызвать в месте вызова метода + какой-таки конкретно метод мы переопределяем в классе-наследнике
>>3236423 Такого нет. В каждой новой шараге куда ты придешь, у каждого занюханого тимлида будут свои понятия о бестпрактиках и как правильно должен быть устроен API
>>3236423 Мне, как вкатунцу, в свое время очень помогла Ultimate Asp.Net Core Web API от Code Maze. Авторы пишут, что сами довольно большие проекты делали по описанному ими образцу. Я верю этому.
В то же время я не думаю, что все описанное там бест практисес, но для новичка это очень хорошая база, вполне сможешь поддерживаемые и расширяемые проекты делать.
>>3236423 Любой бест практис - контекстуально зависим.
В одном проекте - можно все через минимал апи прямо в Program.cs нахуярить и это будет лучшим решением для данного кейса. В другом - будь добр гексогональную архитектуру и все вот это вот. Так что одной такой репки нет. Иди смотри разные, пробуй понять, почему так сделано, если имеет смысл в данном кейсе - бери на вооружение, если чел ебанутый и строит интерпрайз левел хелловорды - запоминай что так в данном кейсе делать не надо, если излишне просто для сложных проектов пытается - тоже запоминай и так не делай.
>>3236423 Этих пожалуй поддвачну >>3236842>>3236527 Важно не какие то абстрактные вещи на старте курить а понять вообще что есть в аспе (а есть там дохуя и больше всего)
Пока что мой уровень - в контроллере дергать еф. А если какая-то логика часто используется, выносить в отдельный сервис Буду тогда лопатить гитхаб дальше
>>3237379 >в контроллере дергать еф Ну вот тут можно уверенно сказать, что в большинстве мест тебе за дерганье слоя данных из контроллеров дадут по рукам. Старайся всегда делать контроллеры максимально тупыми в идеале просто пара строк - вызов нужного сервиса который сделает работу и возврат его ответа наружу.
Добрый день, ребят, подскажите, пожалуйста, я правильно понимаю, что паттерны State и Dependency Injector отличаются следующим: - DI прокидывает интерфейсы, а State классы - DI инъектирует в Inject-оре, что позволяет распределять в одном Inject-оре зависимости сразу в несколько классов, а State делает выбор сам в себе (в контексте) - У State есть переходы в состояниях, в то время как у DI их нет (вот в этом сомневаюсь, по идее я же могу в Injector всё что угодно написать, в том числе и реализовать переходы, храня enum-ы в массиве под каждый класс, чтобы помнить их состояние)
Есть ли ещё что-то, что я упустил? Заранее благодарю за помощь
>>3238189 Многие паттерны по коду выглядят как братья, а то и вовсе близнецы. Поэтому разница в "зачем они нужны", даже если в итоге отличие только в названии. Декоратор и прокси для класса с одним методом могут выглядеть идентично в реализации. Но все же это разные вещи по семантике название указывает на разницу. В случае с декоратором у нас просто обернутый объект с полным контрактом, а в случае прокси мы знаем что нам подсовывают заглушку с частичным (а то и иным) контрактом (с целью легковесности или контроля доступа). И вот уже этот наш прокси похож (а то идентичен) на паттерн адаптер по коду...но цель адаптера адаптировать контракт под имеющийся контракт, а не заботиться о весе или контроле доступа.
Так что не смотри на реализацию. Смотри на семантику - она отвечает на вопрос "КАКИЕ ЗАДАЧИ решает паттерн"
Также нет никакого смысла реализовывать паттерн академически. Задачи нужно решать, а не паттерны кодить.
>>3238273 Спасибо за совет, просто это мои первые паттерны и я начал с неправильного подхода в их изучении >>3238308 >"КАКИЕ ЗАДАЧИ решает паттерн" Вот этого я до конца так и не понял. Если State нужен, когда поведение зависит от состояния, которое меняется во время выполнения программы, то что тогда решает DI? разве не тоже самое?
>>3238361 Эти паттерны решают вообще разные проблемы.
DI это про внедрение зависимостей сервису (классу). Обычно через конструктор (хорошо) или через сеттеры (фука кака). В любом случае тут семантика ИНИЦИАЛИЗАЦИИ, то есть эти зависимости нужны на стадии инициализации объекта.
State же просто подменяет вложенку В ЛЮБОЙ МОМЕНТ в классе не трогая сам объект, который может быть уже у 100500 клиентов захвачена ссылка. Для возможности замены и выставляется метод смены этой вложенки.
И напомню - не стоит упарываться академически. Есть проблемы - есть общие решения. Не потому что кто то сказал "решать надо так", а потому что похожие проблемы приводили людей к похожим решениям. Эти решения записали и дали им имена чтобы форматировать мозги новичкам, и, что важнее - для коммуникации. Когда тебе сказали "тут такой паттерн", то ты сразу знаешь где чего искать.
Пример решения проблемы. У тебя класс, пишет в базу, база может упасть и тебе нужно в этот момент писать в файл. Что ты будешь делать? 100500 если в каждом методе? Да проще же сделать как в паттерне State (ведь это буквально смена внутреннего состояния), то есть 2 вложенки и один метод который их переключает по своей логике. и ПЛЕВАТЬ что нет внешнего метода SetState - задача решена. В жопу академичность. Нужно ИДТИ К ПАТТЕРНУ и остановиться когда задача решена (с) кириевски вроде
Подскажите пж дурочку по асинк, правильно понимаю? Такой подход лучше всего подходит для io баунд задач и в начале берёт поток для старта задания, потом возвращает поток в пулл, но ивент Луп местный проверяет результат, а потом для обработки результата снова новый поток из пулла берёт. Все так? И что для серьезных вычислений цпу баунд лучше подходит мультипоточныы параллельный подход с разбиением над подзадачи?
>>3238521 Нужно отделять мух от котлет. TPL (и связанный с ним асинк) являются унифицированным способом работы с тасками (ака задачи). И НИКАК не затрагивает "как оно выполняется" окромя фабрики Task.Run()
Выполнение же отдельно. I/O задачи будут выполнены на I/O потоках, cpu задачи на тредпуле, долгому выполнению можно и поток выделить (тратим время на создание, но зато не занимаем пул), а то и процесс. Или вообще ничего ибо, как я уже сказал, выполнение котлеты, а таски это мухи.
>>3238361 >Если State нужен, когда поведение зависит от состояния, которое меняется во время выполнения программы, то что тогда решает DI? разве не тоже самое?
Вот смотри, пишем конструктор в DI
ClassA(serviceA a , serviceB b) { this.a=a; this.b=b; }
Теперь что мы не используем DI и вызываем его прям ClassA() { this.a = new ServiceA(); this.b = new ServiceB(); }
Казалось бы разница минимальна и ничего не меняется... Но что если у сервисов конструкторы тоже принимают некоторые сервисы, например БД? Получается уже такая каша
ClassA() { this.a = new ServiceA(new DB()); this.b = new ServiceB(); }
А теперь вопрос, а если нашей БД нужна строка подключения? Пишем вот ак ClassA(string connectionString) { this.a = new ServiceA(new DB(connectionString)) this.b = new ServiceB(); }
А что если если у нас будет ещё несколько классов посредников, например добавим репозиторий или UOW? this.a = new ServiceA(new UoW(new Repository(newDB(connectionString))); И кроме того, про строку подключения, должны знать все классы в цепочке.
>>3238521 Асинки нужны для микросервисов. Ты вызываешь один сервис, другой, десятый, идешь в бд, в редис, до получения ответа тупо ждешь. Параллельно с твоим кодом крутятся еще пару тысяч таких же обработчиков. Выделять каждому по потоку слишком жирно, ведь они большую часть времени ничего не делают. Для таких задач придумали асинки. Для тяжелых вычислений и для фоновых задач в десктопных программах лучше подходят классические треды. С ними удобнее работать.
>>3238871 >в десктопных программах лучше подходят классические треды. С ними удобнее работать. глупости. в десктопном софте такой же асинк во все поля, а если где надо посчитать то в дело вступает Parallel и LongRunning. В остальное время потоки пула никто не жрет, и выдать поток из пула на долгую работу никак не вредит.
>>3238928 Асинк на десктопе используют джуны, которые сами не понимают, что делают. Они наслушались хуйни на ютубе про "асинк круто треды плохо" и хуячат асинки везде. Параллел - это прообраз тасок, сейчас уже неактуально. Треду можно задать параметры при создании. Тред можно просто прибить через аборт, когда юзер нажмет отмена. С тасками придется ебаться с токеном и все равно гладкий юзер экспириенс не получится. Ты просто не сталкивался.
>>3238990 >Асинк на десктопе используют джуны, которые сами не понимают, что делают ахах лол. скорее это деды используют древние треды напрямую ибо софт был написан 20 лет назад. >Параллел - это прообраз тасок, сейчас уже неактуально. сразу видно чела что НЕ РАЗБИРАЕТСЯ в вопросе. >Тред можно просто прибить через аборт Все понятно. ты ДЕД который пишет на дотнете 2.0 (не кор) потому что иначе бы ты знал, что аборта больше нет. > тасками придется ебаться с токеном и все равно гладкий юзер экспириенс не получится видимо у тебя лапки. все работает отлично. единственная проблема - когда чтото не поддерживает отмену, но тут уже не проблема декстопа как такового.
>>3239007 А вот и первый дурачок с ютуба. Поридж, ты бы хоть поинтересовался, почему они задепрекейтили аборт. Правильно, потому что ньюфаги вроде тебя использовали аборт в тасках, вместо дрочения токена, и все ломали к хуям.
>>3239051 гм. то есть ты все же дурачок оказывается ну ок. народ посмешишь с утра, который тебя прочитает ну таких дурачков тут много забегает, жависты например. так что вам привычно выставлять себя имбецилами.
Есть тут адепты DDD и чистой архитектуры? Всегда мучал вопрос, вот есть доменная сущность. Мы её достаём из бд, потом что-то в ней меняем, а дальше нам её нужно сохранить обратно. Вы че получается, каждый раз целиком перезаписываете всю сущность? А если это какой-то агрегат где есть дочки, например, хрестоматийный заказ и позиции в заказе. Каждый раз сами отслеживаете что там поменялось? Ладно если там доменные сущности напрямую через EF мапятся в бд и используется внутренний changre tracker, а если даппер или linq2db? Просветите, пожалуйста, как это у вас на проекте работает.
>>3239223 Первый раз об этом слышу и только от тебя. Обычно наоборот все говорят, что DDD хорошо ложится на чистую архитектуру, как раз все твое ддд лежит в домене.
>>3239217 Ты занимаешься хуйней. Архитектура - это буквально говно без задач, лучшее применение для книг по архитектуре - подпереть ножку стола. Времена абстрактных фабрик прошли, сейчас пишут на голанге с анемичной моделью, а не наворачивают абстрактные абстракции ради абстракций. Надо пересчитать сумму заказа - просто возьми и пересчитай, блеать, это называется проводка, это придумали в 1С еще до твоего рождения.
>>3239332 Спасибо за мнение, анон. Но вопрос был не в том, как мне что-то сделать, а как живут с ддд и чистой архитектурой другие. Я ни то ни то сейчас не использую. Обнял.
>>3239383 Хуево живут. На проде все тормозит, эту проблему пытаются решить апгрейдом железа, цена серверов растет в геометрической прогрессии. Пытаются напердолить многоуровневые кэши, которые всегда глючат, пользователи жалуются, менеджмент отрывается на разработчиках. В какой-то момент приходит новый СТО и решает выбросить к ебаной матери старый DDD копролит и переписать все на микросервисах, без хитровыебаных архитектур. Система оживает.
Мужчины У меня есть херовый сервак где свет отключают все время И есть еще один комп Хочу в крайних случаях включать второй комп и как то синхронить данные в двух базах на этих двух компах Что гуглить?
Из придуманного запросы последних данных в бд в конкретной таблице и сравнение различий, но может у этого действия есть название
>>3239217 Ты смешиваешь ДДД и работу со слоем данных. Не надо так делать. ДДД это про то что у тебя есть язык домена, на котором разговаривают условные пользователи твоей программы. И модель, со всеми прикладными частями твоей программы, идет от этого домена.
Т.е. как-бы ты можешь написать программу для учета товаров на складе - говоря на языке нормального такого CS. У тебя просто есть кортежи значений, сурогатные ключи, память, вычислительные модули, процедуры, функции, указатели и вот это вот все. Но в таком случае - будет дохуя лишних преобразований вот этого всего в то что надо пользователю программы.
А можешь - взять и выделить такую сущность как товар, накладная, склад, цена, остатки по складу, дебит-кредит, баланс, и вот эта вся залупа.
А далее - на этот скелет модели - накладываются разделения по тому самому домену - какая часть приложения что должна делать. Т.е. если со стороны разраба-психопата, можно взять, и в Program.cs все сразу хуйнуть, и оно даже будет работать, а дальше -ебись оно конем; по всем правилам DDD ты проектируешь и сервисы в зависимости от домена, т.е. вот у тебя есть, условно, бухгалтерия, склада, контрагенты и т.д.; у тебя и сервис бухгалтерии появляется, ты спрашиваешь у бухгалтеров, что на вход, что на выход, какие преобразования и как происходят и дотошно воспроизводишь эту всю залупу в программе. А есть люди, которые занимаются приемом товара на складе - у тебя сервис товаров для склада появляется, и вот те же сущности что в реальном мире бы отправлялись со склада в бухгалтерию - отправляются в сервис бухгалтерии из сервиса склада. Так вот строится "приложение".
А конкретно, как у тебя в БД будет записываться - у тебя должен быть просто инфраструктурный слой, который сделает это максимально эффективным образом. Т.е. скорее всего - раздербанит аггрегаты на сущности, посмотрит, изменилось ли у сущностей что-то из вэлью и если изменилось - то что изменилось - в БД и запишет.
Короче. ДДД это более высокоуровневая абстракция. Если ты думаешь на этом уровне - считай что у тебя где-то есть магическое хранилище, которое умеет делать все так как надо. Думать о ДДД и таких вот низкоуровневых моментах - это стрелять себе в колено. Да. Зачем это надо. Затем, что программа, внезапно, решает проблему реального мира. И, условная, тетя Залупа Эдуардовна, не знает и не хочет знать, что есть какие-то там базы данных, какие-то непонятные массивы, функции, JWT, бравзеры и прочее, она хочет загрузить файл эксель, нажать кнопку: рассчитать баланс, и пойти пить чай, обсуждая, какая же новенькая Светка - шлюха, строит глазки Петрову, а Петров - тоже хорош, лыбу давит; о, а видели, чо Нюрка учудила, в зеленый выкрасилась, молодиться, стерва, может мне тоже в синий покраситься?
>>3240126 Спасибо за развернутый ответ, только ты ответил не на тот вопрос, что я задавал. Я знаю что такое ДДД и для чего оно нужно. Я понимаю, что сохранение в базу это инфраструктура, которая к ДДД не относится. Вопрос был в том, как именно оптимальным образом реализовать эту самую работу с бд, когда она у тебя существует изолировано. Ты же не будешь вносить в свой слой домена логику для отслеживания изменений, ведь так? У тебя есть интерфейс репозитория с методом Save который принимает на вход твой агрегат/энтити. И в репозитории твой агрегат становится тупо данными. Как в таком случае реализовать апдейт, каждый раз лезть в базу, извлекать текущее состояние и вычислять дельту?
>>3240137 Тут все зависит от того внутри одного процесса изменения происходят или нет. Если да - то ты тупо на слой приложения отдаешь прокси, с которым работает твое приложение, и которое фиксирует все изменения состяония. Когда приложение делает "Save", инфраструктурный слой - смотрит, а действительно ли что-то изменилось у данного объекта. Если изменилось - обновляет то что изменилось, если не изменилось - то вообще ничего не делает. Если межпроцессное(микросервисы, хуе-мое, твоя сущность в 10 разных местах может меняется и гоняется то в жсонах, по grpc, то в XML'ках), то ты делаешь снепшот в момент начала транзакции, когда транзакция завершена, сравниваешь значение которое пришло после, и вносишь изменение если они нужны. Опять же, наиболее оптимальным образом.
>>3240139 Интересный вариант с прокси. Но для прокси же надо будет создавать наследника, а обычно все наоборот воняют, что наследование не кул. Ещё многие рекомендуют максимально все классы делать sealed. Я вообще не адепт DDD, скорее даже хейтер, просто было интересно как люди борятся со всеми сопутствующими ддд неудобствами. Спасибо за ответ.
Здравствуйте. Подскажите пожалуйста, насколько рабочий план попасть в разработку через постель администрирование, технического инженера и прочий саппорт? Я посмотрел требования, и в сущности у меня больше шансов в поддержку попасть, чем сходу в разработку. Вопрос лишь в том, в каком направление двигаться: знание винды, powershell, а дальше что? Линукс, как я понял, несмотря на распространенность в данном контексте ничего не даст. Или нет? Спасибо.
>>3240126 >ты спрашиваешь у бухгалтеров Проиграл на всю квартиру. Как же далеки книжные теоретики от реальной разработки. Ебаного инфоцигана Мартина самого бы отправить общаться с бухами.
>дотошно воспроизводишь эту всю залупу в программе Потом меняется форма Б10-У я вся твоя красивая модель идет по пизде. Поэтому бывалые разрабы сразу кладут хуй на ДДД и работают с реляционной моделью, она более гибкая.
>>3240137 Просто используй анемичную модель. Забудь про волшебные объекты, которые сами себя отслеживают. Ты литерали создаешь себе проблемы из ничего, потом охуеешь это все отлаживать.
>>3240268 1. ДДД эт не мартин 2. Ты же я думаю тоже не остаешься на уровне голых сущностный реляционной БД. У тебя не Table1 Table2, Table3, а какие-нибудь Users, Roles, Claims, допустим. И у них не Column1, Column2 а Name, Email. 3. С бухами, не ты общаешься. С бухами общается аналитик. 4. Домен не может внезапно взять и полностью поменяться. У тебя как был отчет - так он и остался, просто ты его под новые условия домена изменяешь.
Релационная модель, это либо твое изобретение, либо неправильное использование и понимание того что такое ДДД. Зайди, блядь, да посмотри структуру той же базы любого бизнеса. Там ВСЕГДА, блядь, идет от структуры той предметной области, в которой оно применяется. Для библиотеки - никто не оперирует понятием таблица, нет, блядь, там всегда будет книга, автор, жанр, читательский билет. Для вуза - никто не оперирует понятием таблица, будут Студенты, Курсы, Преподаватели, Предметы и т.д. Короче. Да. Если читать не хочешь - так херню не придумывай, будь няшей.
>>3240165 >насколько рабочий план попасть в разработку через администрирование Не рабочий. Через администрирование реально попасть в девопс инженера, но не в разработчика. При переходе из одной ниши в другую весь опыт обнуляется. Если ты работал в техподдержке а хочешь стать C#-разработчиком, ты начинаешь с нулём опыта в кармане. Они говорят, не ну это понятно что вы работали сисадмином, а вот конкретно с entity framework у вас какой опыт? Ты говоришь, никакого. Они, а ну ясн. Значит начинающий. Причём, это случается даже в пределах одного языка программирования. Если ты пишешь на typescript и используешь react. А им нужно typescript и vue. Тебя спрашивают, а вот вы с vue работали? Ты - не-а. А ну ясн, простите но нам нужен человек который знает vue.
>>3240316 Смотри, у тебя есть Накладная, в ней Позиции. При изменении позиций надо пересчитать ндс. Рич ооп - у тебя объект Накладная, у него свойство Позиции, ты добавляешь туда объект Товар, а дальше оно само магически внутри все обновляет и пересчитывает. Классика легаси монолитов на джаве. Анемик ооп - у тебя сервис накладных, у него метод добавить_товар(id_накладной, id_товара, колво). Этот сервис все высчитывает и обновляет. В особо тяжелых случаях рассчеты ведудтся вообще внутри хранимки, чтобы не гонять данные туда-сюда. Обрати внимание, используются не объекты, а интовые id, потому что объект лежит на другом сервере и его еще надо загрузить, а там 100500 полей и у нас таймауты. Так пишут современный бэк на голенге. В первом случае ты делаешь вид, что никакой бд нет, сети нет, нагрузки нет, все работает на магии и волшебстве. Во втором - ты признаешь, что бд - это самое узкое место в твоей системе и строишь архитектуру вокруг бд, а не вокруг влажных фантазий теоретиков.
>>3240345 Спасибо за ответ. С этим понятно, тогда немного по другому сформулирую вопрос. Какое направление наиболее близко к разработке? Пускай даже косвенно, главное, чтобы полученный опыт можно было считать хоть отчасти релевантным.
>>3240398 >Какое направление наиболее близко к разработке? Разработка. Не весь опыт одинаково ценен. Если ты пошёл проработал 10 лет говночистом, то тебя не повышают до директора. Ты так и остаёшься говночистом. Точно так же, если ты пойдёшь в какую-то простую нишу, типа техподдержки. Да, у тебя будет опыт. Но ценность этого опыта нулевая, даже со знаком минус. Поскольку техсаппорт считают какими-то мальчиками на побегушках. Ну типа, если ты пожал руку опущенному, то ты сам становишься опущенным. Так же и с саппортом. Отработал - зашкварился.
>>3240278 У меня такое ощущение,что все очень невнимательно читают. Ещё раз говорю, вопрос не в том, что мне использовать, а как эту проблему решают адепты ДДД.
>>3240375 Почему-то самый быстрый код который я видел в своей жизни - был написан именно с применением DDD. И да, объектики добавлялись в модельку а инфраструктурная магия все что надо делала. Я не знаю какие там у тебя нагрузки, что надо инты гонять по приложению, но я не думаю что были выше того что было там. Там был TCP сервер, который обрабатывал заказы с терминалов оплаты, и который 10млн коннектов держал спокойно на сервере с 16 гигами оператвики, и средним RPS в районе полумиллиона на зивончике конца нулевых годов. Еще и сервера были с ХДД. Да. Тот код был на жаве. Так что МБ все же не в DDD дело? Потому что я не думаю, что у тебя там реально какие-то хайлоады, вот ну не думаю, хоть убей.
Ну да ладно. Жава - медленная, а чтобы было быстро - надо инты гонять.
>>3240627 Иными словами, классический джава копролит с конкаренси, который кеширует у себя всю базу и так работает. Как только ты попробуешь его замасштабировать, он пукнет и умрет. О том и речь, в DDD можно играться на локалхосте, как только ты перезжаешь в облако, DDD идет нахуй. Сейчас не 1995 год, бэк пишут на серверлесе, а не ебутся с мьютексами.
>>3240856 Ну не знаю. Оно до сих пор работает. Всю базу оно не кешировало. Но да, кеши были для "горячих" вещей. С масштабированием - единственная беда была в том, что каждому инстансу - нужна своя база, но опять же, там это решалось, уже не буду в детали вдаваться.
Yoba1 или 2? Задача получить хранимое shit так, чтобы в yoba оно не менялось. И там и там возвращается копия, но свойство хоть и "логичнее", метод для получения копии всё же корректнее, так? Или без разницы?
>>3241111 ну первое активно используется, а потом приходит анон и начинает орать "ааа (цензура) очень тяжелое свойство сделано так в итоге нужно его запоминать в переменную. Откуда (цензура) я могу знать об этом пид(цензура)"
>>3241082 Второе. И обозвать метод GetShitCopy() чтобы было понятно, что ты именно копию возвращаешь, а не оригинал. Алсо, как вариант, если Shit не должен в принципе меняться, то проще его сделать record'ом.
>>3241082 Ни то ни другое. Ты должен в Shit сделать метод: CreateCopy Вот эта вот хуйня что методом, что свойством - хуйня. Потому что с какого-то хуя Yoba - рождает новые экземпляры Shit. Если суть существования класса Yoba в том чтобы создавать копии, тогда это должен быть метод. Свойства, семантически - это состояние объекта. Я, как клиент класса Yoba - не ожидаю, что будет создана копия. А потому - делай методом, тогда оно будет понятно.
>>3241113 >>3241125 >>3241133 >>3241412 А если в Yoba самое ценное - это Shit, и, грубо говоря, yoba существует ради shit, но при этом говна в нём как бы нет - публичного нет ни поля, ни свойства, ни даже метода "вот моё говно, смотри", только копию можно получить, но явно не понятно, что это копия говна из именно этого объекта йобы. Как-то это странно, нет?
Понимаю, что пример хуёвый, но если нужно использовать изменяемый ссылочный тип то в любом случае получится хуйня?
>>3241758 Да никого не должно волновать что ты делаешь у себя в геттере. лишь бы это было легким. Например, из за тупости разрабов шарпа они не сделали Ilist наследником IReadOnlyList, да и вообще я могу захотеть прямо запретить изменение лист и тогда у меня будет свойство
вот тебе псевдокод public IReadOnlyList Items => new ReadOnlyWrap(_items)
>>3242136 Идиотизм идеи в том, что список должен быть иммутабельным. Сама идея листа, это динамический список. Обдолбятся своим ФП которое уже забыли и сношают потом себя в подобие массивов.
>>3242673 Ну, если ты под тем - ок или не ок это делать - не ок. Но блядь. Я сегодня распутывал такую упоротую упаковку спагетти моего коллеги, что валидатор в маппере - это пустяки.
>>3242787 хорошему программированию. в хорошем программировании для всего используется минимальный и самодостаточный контракт, а не костыли. Но это не к шарпу, где все используют IList и забивают болт на IReadOnlyList ибо неудобно.
>>3242809 В хорошем программировании ты делаешь задачи бизнеса, а не ебешься с бороу чекером или еще какой душной хуйней. Просто потому, что шиз на авторе так решил. Дроч на ридонли интересен только аутистам с окр, нормальным людям похуй.
>>3242817 ага слышали такое. Задачи бизнеса. Хуяк хуяк и в продакшен А потом бац и оказывается то нулл это ошибка на миллиард долларов. Потом бац -и самолет или космическая станция падает. Потом бац - и синий экран смерти по всему миру и ущерба на миллиарды.
>>3242963 Зато не душно и адвокатно. Да да - АДВОКАТНО, ведь потом только на них надежда чтобы они доказали что ты ничего не должен, что все предоставляется "как есть без гарантий" )))))
и эти зумерки мне еще про иммутабельность что то чешут. смешно просто. А все потому что >с бороу чекером или еще какой душной хуйней зумерки НЕ В ТЕМЕ вообще, поэтому и несут херню.
Говняк если я буду возвращать обьект шаблонный { успех, еррорМесседж, результатОперации, возможноЭксепшн } из каждого сервиса и в контроллере решать, какое сообщение клиенту отправить? А необработанные случаи дополнительно ловить глобальным хэнлдером
На гитхабе листаю проекты, у каждого свой подход, начинаю гуглить минусы и плюсы - разьебывают в ноль
>>3243170 Все 2хх возвращаю как есть без обёрток, всё остальное в одинаковой оболочке с ошибкой, кодом, исключением, трейсидом, для 400 с модел стейтом
>>3243170 Нормальный подход, только он бесполезен сам по себе в вакууме - к нему еще дохуя экстеншенов надо прикрутить, чтобы это все работало как задумано. Типа .IfSuccces, .IfFailure, .Ensure, .Map и т.д. плюс их асинхронные версии. Ну и вяких .ToResultOk, .ToResultFail дженериковых тоже.
>>3243082 Маня, ты же ни дня не работал разработчиком. Твой код никогда не был на проде. Сидишь пердишь на кафедре в мухгу и рассказываешь охуительные истории.
>>3243368 Я не он, но обработка штатных ошибок предусмотренных в бизнес-логике/алгоритме через Exception-ы это тоже говно, т.к. при большом их кол-ве превращает код в лапшу. Плюс их особо никак в контракт не зашьеш. Остаётся только в xml doc-ах описывать, что там вылететь может. Если в коде используются нормальные примитивы для результатов операций, то код, имхо, читаемей выходит. Плюс самодокументируется лучше. Плюс побуждает-таки людей нормально обрабатывать бизнесовые ошибки. А с помощью исключений я обычно по-настоящему исключительные ситуации обрабатываю (разрывы соединений, out of memory, говно каким-то образом прославившиеся в аргументы метода через все валидации и т.д.). Плюс исключения в горячем коде могут сильно производительность ронять, т.к. их выброс и перехват это достаточно тяжелый процесс.
>>3243170 Нет, не говняк. Это то к чему приходишь, поебавшись с эксепшинами. Только самописное - разве что в случае если дохуя свободного времени или оч хочется поучиться как там, но это не на прод. Для прода - есть готовые всякие ResultOf<T> или ErrorOr<T> и другие расширения. Гуглится легко. И да - это удобнее, это проще в использовании. Это не ломает твой перформанс, который важен, когда у тебя хайлоад пошел.
>>3243540 я мимокрок нормально будет выглядеть, стандартно а не чужеродно. Тут вам не раст, где исключений нет и поэтому есть средства для удобного разбирания ошибок (хотя приходится их разбирать и компилятор ПОЗАБОТИТСЯ о том чтобы ты не забыл их учесть) и не го, где вроде такая же шняга вместо исключений.
Бутет ебаная каша с постоянными try-catch, будет надо пилить где-то глобальный обработчик исключений.
А потом - тебе прилетит задача: Для всего нового апи - надо фронту возвращать не просто код, а полное описание, что пошло не так, и как пользователь может это исправить, потому что UI/UX'еры почитали хабр, и там жалуются, что ошибки неинформотивные, и надо дать информативные, еще и локализованные, еще и с картинкой красивой сразу с бека, чтобы если фронт не открывается, человек красивую картинку в ответе мог посмотреть. И вот ты такой полезешь в свой глобальный обработчик и будешь по стектрейсу определять, какое нахуй там апи новое, какое старое, потому что старое - трогать не надо, его при интеграциях используют, и ломать его нельзя.
Вот таким вот хуем, ты на уровне сервиса, если уж надо - все исключения перехватываешь - и возвращаешь контроллеру нормальную ошибку, которую вы договорились возвращать, с локализацией и красивой картинкой.
>>3243579 Вот это фантазии как раз это с Match будет каша на каждом уровне. А исключения потому такие и есть чтобы НЕ иметь этой каши с матчами/кодами возврата/Error и прочим.
>надо фронту возвращать не просто код исключения не отрицают код ошибки и любую информацию по ее поводу. А твои матчи не являются волшебной таблеткой ибо страдают тем же недугом - придется плясать если у тебя такие требования. Ведь разницы так то в "что прислать наверх" кроме "как прислать" - явно делая портянки на каждом шагу, или не прописывая, но неявно.
>какое нахуй там апи новое, какое старое, потому что старое - трогать не над сова на глобусе и хз причем тут твой подход как лечение. Одно с другим не связано.
>возвращаешь контроллеру нормальную ошибку, которую вы договорились возвращать, с локализацией и красивой картинкой таким же, как и ты - ты где то все равно вынужден будешь прописать "эта ошибка - нам нужно показывать енто". так и тут. Разницы по большому счету нет.
>>3243622 >Разницы по большому счету нет Разница как минимум в том, что смотря на сигнатуру метода контроллера/сервиса, я сразу вижу, что он вернет и обрабатываю это ровно так же, как обрабатывал бы нормальный результат. В том же месте. Теми же механизмами. Не добавляя try-catch на каждый чих, не делая какой-то непонятный, хрен где зарытый мидлварь для формирования ошибок.
>>3243540 Проиграл в голос. Понасмотрятся своего раста и ябутся в жопы. Наркоман, какой матч? Какой ретурн нью еррор? Ты совсем ебанулся? Достаточно просто бросить эксепшен, поймать его в глобальном обработчике, записать ошибку в лог и вернуть 500.
>>3243637 тут 2 крайности. явное против неявного. boilerplate против его отсутствия. Каждый сам выбирает свой стул. В жаве вон есть чекед исключения, но они не взлетели по причине именно "да задалбывает все это указывать".
И не нужно мне говорить что второй стул лучше. Это просто второй стул.
Не могу нигде найти, а может быть у рекорда член типа базового рекорда? Как у класса object? Другими словами у типа record class какой ультимативный базовый тип?
>>3244052 По сути record - это обычный класс, к которому компилятор потом добавляет переопределение некоторых базовых методов (типа ToString, Equals и т.д.)
>>3244082 > клиенту все одним кодом ошибки будет возвращаться? Да, а что? У клиента только один способ обработать ошибку - показать текст ошибки пользователю. > Можно тогда уж на все 200 отправлять, только жсон не слать в ответ Можно и JSON слать. { "success": true, "error_message": null, "body": { ... } }
>>3244072 >Я хотел зафиксировать контракт, т.е. что бы в член рекорда можно было только произвольный рекорд записать а не произвольный класс. Правильно говорят - хуйней страдаешь. Если нужен контракт, то выделяй его и используй.
>>3243680 Да-да. А потом - тебя ебут в жопу клиенты и тестировщики, что ошибки нихуя не понятные, и вообще - на каждую ошибку надо красивую картинку, и текст что сделать чтобы пофиксить, еще и чтобы кнопка была чтобы автоматом пофиксить с клиента. Ну ты понял. Уже проходили, заебало.
>>3243843 Второй стул - универсальнее и проще в плане поддержки. У тебя контракт, метод вернет это или ошибку. С эксепшином - у тебя нет контракта. Тот кто его кидает - считает что кто-то поймает. А действительно кто-то поймает - хуй его знает. В результате, у тебя сигнатура: User CreateUser(CreateUserRequest request); Но хуй там плавал, там под капотом: CreateUserRequestValidationException чел кинул, или EmailInUseException, или EmailInBlackListException и т.д. и чтобы узнать, что тебе эту хуйню надо обрабатывать - тебе надо лезть в код этого сумрачного гения, и проверять, а кидает он что-то или нет. А с тем, что эксепшины - вверх по всему стеку летят, тебе надо во все что чел вызывает залезть. В пизду короче. Если хуйня может случиться - вызывающий должен знать об этом явно.
Прошёл курс для начинающих по C# от Microsoft. Что дальше? Когда ждать офер от Билла Гейтса? Не, ну серьёзно, что делать дальше? Я посмотрел, что ещё нужно выучить для вебмакаки, и мне стало страшно.
>>3244186 Прочитай про ASP, сделай приложение какое-нибудь на основе. С БД и всем таким. Условно - приложение для заказа столиков в ресторане. Или выбери что тебе нравится. Желательно чем бы сам пользовался, чтобы не заебало на середине. Если оч хочется - прикрути фронтенд. Собственно. Да. Как сделаешь - иди на собесы.
>>3244119 >А потом - тебя ебут в жопу клиенты и тестировщики, что ошибки нихуя не понятные, кому понятные? 99% кода что ты используешь как пользователь написано с исклчюениями. мир не умер. что делать пользователю с подробностями? он не разработчик и детали более нужного ему не нужны.
>Но хуй там плавал, там под капотом: Ну значит нужно нормальных чуваков код брать. который не будет кидать исключение на валидацию, делать норм исключения и помнить про границы контекста (что является тем самым про что ты задвигаешь. ведь тебе из глубин не придет "деление на ноль", а по пути обернется во что то более общее. Так и с исключениями.
>>3244196 > кому понятные Конечному пользователю. Че ты тупишь.
>99% кода что ты используешь как пользователь написано с исклчюениями. мир не умер. Большая часть софта который конкретно я ежедневно использую как пользователь - написана на сях. Какие нахуй исключения в сях?
>что делать пользователю с подробностями? он не разработчик и детали более нужного ему не нужны. В бесткейсе - информация должна быть достаточна, чтобы пользователь - мог самостоятельно устранить проблему или, а если ее нельзя устранить - понимал причину и не горел, что все пиздой накрылось - глючное говно, по что вам столько деняк плотют.
>>3244273 >Конечному пользователю. Че ты тупишь. что конечный пользователь должен видеть особого кроме того что ему понятно? не вижу как бы монады твои давали больше информации чем можно было бы дать другими путями
ЛИБО ты прописал что показать пользователю, ЛИБО НЕ прописал - монады тут совершенно не причем.
>Большая часть софта который конкретно я ежедневно использую как пользователь Так и запишем - чел первый день в вебе и не использует никакой сайт кроме двача.
>В бесткейсе - информация должна быть достаточна >В бесткейсе >пользователь ох сколько я видел такое "читай подробности в логе". идешь читаешь - толку ноль ибо ты ничего не можешь сделать кроме как отправить лог в саппорт. в 70% и это не чайники мы. Обычному пользователю твой стектрейс нахрен не всрался.
И такой пример. Если А ссылается на В, то и В должна на А. Так и свербит сделать как во 2-ом варианте, но добавить аналогичный вызов в A.Add(B b) не получится и методы Add у А и В не равнозначны, и тогда как быть? Остановится на 1-ом варианте?
Аноны, есть задача, похожая на описанную здесь https://refactoring.guru/ru/design-patterns/visitor только у меня нет ограничения на расширение классов. Так что я создал интерфейс IXmlSource с методом GetXml, но тут возникла необходимость по разному форматировать итоговый результат, в зависимости от настроек пользователя, языка и тд. Так что я дополнительно решил создать интерфейс IXmlFormatterProvider, с методом GetFormatter(Type), который должен возвращать форматтер для заданного типа. Сам форматтер имеет метод string Format(object). Собственно насколько такая реализация имеет место быть, может существуют лучшие решения задачи?
>>3219660 Automapper - хуита. Его любят кодомакаки, потому что с ним кода получается больше, чем без него. Настрочил тонну конфигов и можно показать тимлиду, мол, не бездельничал.
>>3246419 Да ладно. А альтернативы какие? Писать свой класс конвертер, да ещё и с интерфейсом, инжектировать, сохранять в поле? И это меньше кода? При том, что для автомаппера можно сказать, чтобы он замапил друг на друга свойства с одним именем и типом, а в конвертере это всё руками надо перечислять.
Имея некоторый опыт в WPF, я попробовал Авалонию... и сразу запнулся. Я не привык писать разметку ручками, а добавлял объекты, просто перенося гуишкой. Можно ли где-то заполучить такую возможность для Авалонии?
аноны, с шарпом какое-то время в унике работал делая лабы с консолью, винформами и впфом. но сколько-нибудь сам язык знаю. сейчас гребу на ноде на кабана, заебало сил моих нет. хочу свичнуться на дотнет и закатиться в какое-то неплохое место, в связи с этим ковыряю асп.нет и возникли вопросы, как все в реальной жизни устроено, чтобы свои петы приблизить к этому и набить возможные шишки перед собесами.
если я хочу сделать микросервисную архитектуру – делается ли у вас монорепа? в ноде как раз популярно это. а как у вас? 1 солюшен с подпроектами? какой стек наиболее популярен в прлде? видел много 6 дотнета в вакансиях, почему не 7?
и какие подводные в попытке выбиться в шарповый энтерпрайз? щас все бегают с ГОвном, не сильно ли подкосило кол-во вакансий на .нете?
>>3247513 >делается ли у вас монорепа Нет. Монорепы зло. Чаще всего (по крайней мере, то что мне больше всего попадалось), это вынесение модулей, контрактов и т.д. в общие проекты, вроде CommonContracts, CommonServices и т.д. И подключение их уже в репозитории конкретных проектов в качестве git сабмодулей или отдельных пакетов (из собственного нюгет хранилища) Есть конечно места где монорепы используются, но это чаще всего следствие какого-нибудь местного долбоебизма (вроде ебанутых требований от безов или убеждений тимлида)
>а как у вас? Обычно: один сервис - один солюшен. Внутри солюшена сервис разбивается на несколько подпроектов, один основной и остальные вспомогательные (например DAL, Domain, AppServices и т.д.). Всякие библиотеки в своих отдельных солюшенах. Несколько библиотек могут в один солюшен объединяться по каким-нибудь признакам.
>видел много 6 дотнета в вакансиях, почему не 7 Потому что 7 не LTS и никто его в прод не потащит, ровно по той же причине никто не требовал 5-й. Вопрос должен быть - почему 6-й, а не 8-й. Потому что в одобренных партией для импортозамещения линуксов в стейбле есть только 6-й дотнет. Можно конечно на свой страх использовать любую версию, но тогда прощай сертификации и здравствуй проблемы от безов.
>и какие подводные в попытке выбиться в шарповый энтерпрайз? В очень многих местах тебя будут пытаться прогнуть на фулстека.
> щас все бегают с ГОвном С ним носится хуяндекс в основном. Выглядит все так, будто они вляпались в это говно, а теперь не могут в этом признаться и пытаются на конфах убедить всех остальных, что говно вкусное и полезное.
>>3247513 Дотнет умирает, зря ты сюда вкатываешься. Через 10 лет сишарп будет как делфи сейчас. Проблема в том, что идеологией дотнета рулят деды, у которых вечно 1995 год. У них в головах до сих пор абстрактные фабрики и 100500 слоев в проекте. Посмотри на Entity Framework, это же ебаный рак мозга, ты не можешь просто сделать запрос к бд без высирания сотен строк конфига. Почему так взлетели голанг и нода? Да потому что там ты просто пишешь код, который просто работает. Все, блять, никаких солюшенов хуюшенов. Надо сделать запрос в бд - берешь и делаешь, никаких слоев доменной логики и прочей хуйни. Пришли свежие люди со свежим взглядом и выбросили все говно, а в дотнете деды сидят пердят вспоминают свой 1997. Ты сам все видишь по вакансиям, рынок не обманешь. Алсо по вакансиям. В дотнете это или древнее копролегаси с конкаренси, или фулстек в крипто финтех аи стартап оплата ветками.
>>3247701 >мам в интернете пишут неприятное ну мам Малолетний дебил, я работаю с дотнетом еще с 2008 студии и прекрасно вижу, в какую пизду он покатился после ухода Гейтса. Майкрософт стремительно проебывает все рынки, а дотнет из энтерпрайза скатился в нишу говна, где фулстек паджиты дерутся за копейки с хохлами. Это литерали новый делфи. Но ты продолжай верить, что через пять лет ты будешь востребованным специалистом с 5 годами опыта на сишарпе за много денег. Учи xamarin blazor, без работы точно не останешься.
>>3247676 благодарю, анонче за развёрнутый ответ. чет действительно, забавно я проебался, спросив про 7, а не 8, знаю ж, что не лтс.
а по вакансиям – реально лучше не слезать с ноды и пробовать дальше в нее тыкаться? я в целом от ебучего жабаскрипта устал, ибо фронтенд - то по пакетному менджеру раз в месяц, то новый фрейм каждый день, то еще какая хуйня вроде стейт менеджеров каждую неделю. уже реакт в базу ходить может, лол. нода тоже не то чтоб далеко ушла, там немного специфики есть, но тоже одних рантаймов штук 5 уже.
я по этой причине думал срыгнуть в тихую гавань типа асп нета или жабы и спокойно себе жить, ибо гошка пока для меня не понятна, ибо есть какие-то компании и в них проекты сильно отличаются от того, что в тырнетах видел
>>3247815 Анон выше прав. Сейчас в дотнете нормальных вакансий, где ты будешь чистым бэком, работать на современном стэке, с современными подходами к разработке хуй да нихуя. И вкатиться на них после смены стэка будет очень тяжело, так как там обычно большие требования (ибо конкуренция). Плюс половина из этого будет что-то околобанковское с характерной бюрократической спецификой. Плюс учитывая твой бэкграунд с js-ом и нодой каждый первый кабанчик будет пытаться прогнуть тебя на фуллстэка. А это твою проблему фронтовой усталости явно не решит.
>>3247815 Все просто. Смотришь вакансии на мидла по разным стекам. Смотришь на сеньку по ним же, это ты через пять лет. Сравниваешь количество вакансий, зарплаты, насколько охуевшие требования. Понимаешь, что время дотнета прошло и ловить там нечего. Гошка, кстати, простая и похожа на ноду.
>>3247815 >а по вакансиям – реально лучше не слезать с ноды и пробовать дальше в нее тыкаться? Ну х.з. я не люблю джаваскрипт и считаю, что с него стоит в любом случае переползать на любой другой стек. Но это мое мнение и оно может не ролять в твоем случае.
Пацаны. Я устал с миллионом файлов. С завтрашнего дня, для проектов где я работаю один - я буду использовать TopLevel-only подход. 1 Program.cs на проект. И не ебет.
Какой у вас тут положняк по ГУИ сейчас? Помню раньше было несколько полуразвитых технологий разного возраста и разной степени готовности(впф, мауи и т.д.), а сейчас что? Уже порешали всё или так и висит?
Ньюфаг-говнокодер на связи. Можно ли как-то сделать метод который возвращает дженерик тип, но при этом не указывать сам дженерик тип при вызове метода? Ситуация - у меня есть поле object в некоем классе в котором будет храниться List<T>. Если не делать object, то нужно плодить под каждый тип поле, что я не хочу делать. Теперь при его использовании я хотел написать какой-то метод которой вернет мне эту же object переменную с нужным типом. Сам тип определяется по enum'у этот enum у меня еще много где используется Но на этом моменте я просчитался - как можно удобно получить нужный тип? Мне нужно что-то типа:
var myListTypeField = myObjectField as GetType(myEnum);
*Сами типы (в List<T>) которые будут записываться в поле object довольно похожие между собой и у них разница может в пару полей, а все остальные поля идентичны между собой у всех разных типов.
>>3249147 компилятор ниоткуда не узнает выходной тип без указания где то этого типа. В любом случае где то придется тебе его указать чтобы привести к нему.
>>3249392 Ты что-то делаешь не так, потому что usedirect2d работает прекрасно. Только надо еще добавить With(new WindowsOptions() { CompositionMode = new []{RedirectedSurface}), а то окно будет прозрачным.
>>3249315 Что-то типа такого, да. >>3249178 Я могу сделать свич к enum и в кейсах инициализировать поле и писать нужный as type, вот только его нужно будет везде копипастить при обращении к этому полю. Я не понимаю можно ли как-то сделать из него метод и возвращать Type? Пробовал ковырять возвращаемый тип Type и писать typeof(MyClass), но к конструкции as оно не подставляется. >>3249175 Уже думал. В наследовании к интерфейсу у меня будут теряться те пару полей дочернего класса у родительского интерфейса.
>>3249702 >Пробовал ковырять возвращаемый тип Type и писать typeof(MyClass), но к конструкции as оно не подставляется. Потому что надо MyGlass.GetType() as
>>3248856 Смотря что ты хочешь сделать и смотря для чего.
Если просто нужны какая-то кнопочка и какой-то текстбокс, достаточно юзать винформсы. Стили элементов будут зависеть от конкретной ОС.
Если тебе нужен кастомизируемый UI, то твой выбор WPF, но тут ты должен понимать, что там до сих пор дефолтные стили времен висты и они хуй кладут на то, что у тебя, например, на данный момент стоит одиннадцатая версия виндовс и какой у нее стиль. С одной стороны тебе легче сделать кастомный контрол по сравнению с винформсами, но с другой стороны, вероятнее всего тебе придется перелопачивать стили всех элементов, а в сумме это уже не так-то и быстро. Тут если ты не уверен, что тебе нужно — значит не нужно. Вот мне было нужно, потому что я делал плагины для различных прог и мне надо было выдержать стиль той программы, для которой я делал плагин.
Если тебе нужна мультиплатформа, то твой выбор Avalonia. Это почти WPF, но есть недостатки. Насколько я знаю, там проблемы с растеризацией шрифтов и с виртуализацией списков. Но это самый лучший вариант для мультиплатформы.
Ну или ASP.net, если есть возможность сделать приложение веб.
>>3248856 >разной степени готовности(впф ... А в чем заключалось неготовность впф? Тем более, что на момент возникновения мауи (который действительно не готов), впф это уже старичок. Единственное, что майкросфот никак не сделает для впф — это не перелопатила стили под свежую ОС. А еще мне самому пришлось делать собственную систему скинов, потому что система тем — это какая-то хуета, подразумевающая перекраску кнопочек аля светлая\темная тема. А вот чтобы у тебя приложение на лету меняло скин с WIN98 на WIN11 — это уже надо как-то делать самому. Да и не сказать, что сделать это сложно — все готово, но каждый раз на это надо тратить время.
>>3249730 Он хуйню написал. После as должен константный тип быть указан. Это же инструкция для компилятора, а не какая-то конверсия в рантайме. Я, кстати, до сих пор не понимаю, что тебе надо. Можешь код выложить?
>>3249976 Короче я хотел сделать что-то типа как на втором пике. Правда уже вижу что компилятор пишет что это таки object. Пока вижу вариант только с dynamic'ом ковыряться. Еще хотел чтобы вот этот switch был отдельным методом, а затем там где я использую переменную я бы его дергал, что-то типа var answerList = dbAnswer.AnswerList as GetMyType(); Ибо иначе мне везде придется копипастить этот switch.
>>3250150 >>3250151 Я на оборот хотел как лучше, иначе мне нужно плодить 8 свойств, вместо одного и к каждому свойству делать 8 отдельных методов в апи контроллере (и их может быть больше). И нет, шарп основной. >>3250158 А можно сделать дженерик свойство? >>3250175 О, вот это уже тепло, завтра потыкаю.
>>3250361 ты можешь сделать дженерик метод внутри которого будет итоговый тип. но раз ты можешь его сделать, то, скорее всего, они у тебя и так обладают общим контрактом и можно обойтись тупо интерфейсами.
дженерик метод хорош когда тебе нужно описать шаги. типа вот у тебя 100500 провайдеров разных данных и тебе нужно из них извлекать, вызывать другие методы (тоже дженерики) то есть получается много много вызовов разного, а конкретной зависимости от типа нет.
Вот у меня была такая задача - чтение разных данных из разных источников. валидация, фильтрация, сохранение. Данные абсолютно разные - а метод "достал, фильтранул, валидировал, сохранил" один. И я вызываю этот дженерик метод для всех видов данных. Иначе бы мне пришлось копипастить столько раз, сколько типов данных.
Смотрите корочи. Файл без расширения. Это как его запустить то? Если на ставить галочку Создать отдельный файл то есть dll который я собственно потом и запускаю через создание сервиса как в примере [Service] WorkingDirectory=/var/www/helloapp ExecStart=/usr/bin/dotnet /var/www/helloapp/helloapp.dll .......
А с этим файлом что делать? Так же запускать его просто расширение не писать?
В чём может быть проблема? Если запустить так, как показано на второй пикче - работает, то есть контенер создаётся и открывается страничка в браузере. А если через команду, то не хочет. Докер файл создаётся сам visual studio. Мне этот проект надо запихнуть в docker-compose, а эта хуета не хочет работать, хотя в других проектах такого не наблюдал.
>>3250513 Ну хуй знает Я переместил бота в папку /var/www/zalupa если ему так хочется. Хуй знает почему он именну туда лезет, лежал ведь в WorkingDirectory=/opt/TgOrdersBot
При каждой загрузке проекта, часть C# класса не видит XAML часть, в том числе не видит такие методы как InitilizeComponent, хотя класс наследует UserControl. После удаления obj и пересборке все встает на свои места, но я уже задрался каждый раз удалять obj.
>>3251717 У меня фифти-фифти. Всякие старые клиенты или крупные - чому-то на винде. Новые - чаще линуксы. Из крупных клиентов на линуксах - сбер.
Самое смешное во всей этой хуйне, что с клиентов что на линуксах - 0 проблем. Развернули им, все годами спокойно работает, периодически только фичи просют. А у тех что с виндой - постоянно что-то с ифрой, все у них ломается, сразу - ваше ПО - хуйня, лежешь смотреть, там админ-долбоеб что-то недонастроел в виртуалке.
>>3251724 НА СОБЕСЕ СПРАШИВАЮТ ПРО КАФКУ, ПРО КАП ТЕОРЕМУ, JWT ТОКЕНЫ, САГИ И ПОСЛЕДНИЕ НОВОВВЕДЕНИЯ В СИШАРПЕ @ НА ПРОЕКТЕ ДРЕВНИЙ КОПРОЛИТ НА ИИС И ВЕБФОРМС
>>3251717 Последний раз видел что-то на винде 2 года назад. И то с установкой как можно быстрее её дропнуть и перевести на линукс.
Все новое сейчас точно под линукс и контейнеры сразу разрабатывается. Даже универсальность (чтобы в случае чего запускалась на винде) уже не требуют. Тем более, что вот этот анон >>3251775 прав - как оказалось на линуксе оно все проще и стабильнее работает и нет такого дроча как с IIS на винде.
Сап двач. Вопрос по данному пикрилу - эта хуйня работает, но жрет оче много памяти. Не могу понять, на каждой итерации EF понимает, что объекты можно удалить из памяти или продолжает их трекать? Если продолжает как сделать чтобы он этого не делал?
>>3252351 - У ченджтрекера отключи вычитывание при инсерте - Каждую итерацию вставки дергай на ченжтрекере ресет - Читай с AsNoTracking - Лучше используй либы для булк инсерта, вся функциональность ефа тебе тут не нужна
Некоторые пункты выше имеют одинаковый эффект но разными способами. Сам читай что к чему
>>3252355 >>3252358 > - У ченджтрекера отключи вычитывание при инсерте Мне вот это было нужно, но на всякий случай все пункты сделал. Раньше жрало 13+гб и конца и края не было видно, сейчас выше 1 скакнет и сразу чистится. Заебись, четко. Сотни нефти, анончик.
>>3252695 Ещё бы написать это так что бы клятый компилятор/рантайм не оптимизировал. Умным дохуя стал, у нас в стариковском вендорлокнутом швайношарпе таких не любят
>>3252691 ну в коде ты протестировал сколько места занимает такое то количество объектов Task + по идее делегатов и плюс еще массив из тасок. Что измерял хз async/await это не таски.
Срач между сектанатами жавы и шарпа напоминает мне таковой между фанатами нвидии и амд. Последние в своё время совершили ошибку, наслушавшись сказок про раскрытие потанцевала, и сделали выбор в пользу говна (шарп, амуде). А осознав это, начали убеждать себя и весь мир, что вовсе они не обосрались.
сап всем, вот до меня не доходит, как правильно возвращать респонсы из сервиса в контроллер? наверное не так выразился, есть такая ситуация контроллер обращается в сервис, в сервисе допустим происходит проверка пароля и размер файла, и допустим на валидацию пароля я хочу возвращать 401 unauthorized, а на валидацию размера файла 400 bad request, как передавать такое из сервиса в контроллер правильно? ведь контроллер должен все эти iresult делать
>>3253118 Делаешь класс результата (Result например) в котором передаешь собственно результат разоботы сервиса. У него будут следущие свойства: IsSucces, говорит о том удачно или неудачно отработал сервис Value - содержит результат работы сервиса если IsSuccess == true Error содержит объект ошбики, если IsSuccess == false Ну а в ошибку уже пихаешь что нужно. Либо сразу коды ответа, либо свои внутренние коды, которые в контроллере будут мапиться на стандартные. Плюс всякую муть вроде доп сообщений или эксепшенов. Ну и в контроллере через какой-нибудь CreateReesponse преобразуешь это все в стандартный ответ.
В общем. Короткая вводная. Бекендомакака. Коллега - ушел в отпуск с нового проекта. Проект - декстопный. Авалония. Проблема в том, что ЗАВИСАЕТ. Так было когда я пришел вытаскивать, ведь СРОКИ. Суть в том, что бесит жутко. Программулина работает-работает, но в полурандомные моменты времени(полурандомные, потому что после асинхронных операций, но не всегда и не на одни и те же операции) - ЗАВИСАЕТ. И все. Висит пока не убьешь. Как такое дебажить и искать причину? До этого ни с авалонией ни с десктопом дел не имел.
>>3254043 ну, да, я сейчас и читал на метаните, там все подробно написано, просто я как бы в ахуе, с одной стороны хорошо что есть столько сахара, а с другой я просто боюсь банально не запомнить его)), спасибо анон, теперь буду знать и держать в голове что ивенты лучше
>>3254046 лучше чего? event-ы это и есть делегаты. мультикаст делегат по факту. а сахар event лишь прописывает за тебя методы добавления и удаления подписок А сам подход понятен, но выбор неудачен чтобы отписаться нельзя вызвать какой нить token.Dispose() или лайфтайм передать - нужно передать именно тот делегат, что и была подписка с многопоточностью вообще беда. с асинхронностью тоже.
это стандартный механизм реализации паттерна подписчик, но не лучший (хотя идеального не существует - это всегда выбор между стульев с пиками...)
>>3254172 двачую, общался как то с челиком который вроде как микросервисы делал на шарпе, я еще удивился когда узнал что он регулярно, ну типа буквалньо часть его работы копаться во фронте и как то его допиливать, делал он все это по моему на ангуляре, слышал как раз в треде что ангуляр как то по особенному вяжется с шарпом зацените капчу
>>3254187 >слышал как раз в треде что ангуляр как то по особенному вяжется с шарпом Никаких особенностей, ровно так же как и любой другой js фреймвор к - через web api
Как в MVVM реализуется следующая штука. Допустим, я создаю карточку данных сотрудника. В этой карточке три тексбокса и каждый отображает определенное свойство сотрудника: ID, имя и фамилию.
Понятно когда такая карточка предназначена для одного выбранного элемента в списке сотрудников. Но как мне к этой карточке привязать несколько сотрудников? Я не хочу выводить несколько карточек — мне нужна одна, чтобы заполнив поле тексбокса, пользователь разом менял свойства нескольких сотрудников.
Обычно это выглядит так. Если все свойства Name выбранных сотрудников одинаковые, то текстовое поле отображает это имя. Если хотя бы одно значение отличается, то текстбокс остается пустым. Если пользователь вводит значение в тексбокс, то перезаписываются свойства Name всех выбранных сотрудников.
Я знаю про IMultiValueConverter. И я понимаю как вывести данные в сторону текстбокса, но я не понимаю как ИЗ текстбокса перезаписать данные обратно т.к. в этом случае у конвертера нет информации о привязываемом списке.
>>3254332 конвертен не знает - вьюмодель знает. сделай вьюмодель для редактирования карточки и вот она внутри себя будет иметь всех сотрудников 1+ и выводить что надо и обновлять им что надо. а мультиконверт не нужен
>>3254343 >сделай вьюмодель для редактирования карточки и вот она внутри себя будет иметь всех сотрудников 1+ и выводить что надо и обновлять им что надо. Но разве это не проблема вьюхи? С другой стороны, сортировка\группировка\фильтрация списков находятся на стороне вьюмодели и там создается отдельное свойство типа ICollectionView. Может мне сделать что-то подобное?
Надо только подумать как сделать это универсальным. У ICollectionView есть свойство Filter, где хранится делегат на метод в котором содержится логика фильрации, а у меня там будет содержаться логика микширования коллекции в один элемент.
Поясните, как правильно загружать сборки, которые зависят от нативных либ? Для примера, вот я хотел вынести работу с компортом в dll. Если пытаюсь загружать ее через Assembly.LoadFrom(путь) - она загружается, но при попытке что-то сделать получаю PlatformNotSupportedException Начал гуглить. Нагуглил AssemblyLoadContext. Но при попытке через него загрузиться - почему-то не находит нужный мне тип, чтобы создать дальше объект для работы. При этом первым способом - другие dll в которых типа нет никаких нативных и прочих зависимостей - нормально подгружаются.
>>3255082 >скажем, \n работает, а \{ работать не может? потому что интерполяции плевать на \n - она для нее ничего не значит, а вот скобкосодержащий продукт значит.
>>3255082 > Не понимаю. Почему, скажем, \n работает, а \{ работать не может? Ты дурак? \n отрабатывается на этапе компиляции, все остальные НЕ эскейп последовательности в рантайме. Это общая договорённость, в исключениях по типу регулярок нужно эскейпить бэкслеш \\n что бы он переходил как текстовый \n в рантайм а не как байтовый перевод каретки
>>3255098 Большинству вообще похуй. Просто здесь году так в 2020 завелось несколько троллей, которые подливают масла то в шарпотреде, то в жаботреде, причём это одни и те же аноны, которые прикидываются то джавистами, то шарпистами.
Подскажите пожалуйста какой подход я должен использовать Что делать с объектами которые не изменяются и хранят в себе настройки для другого класса? При каждом их создании ведь тратится память и создаётся лишняя работа для сборщика мусора. Создавать их каждый раз, использовать синглтон или статический конструктор? Сам класс осуществляющий работу - ImageConverter. Он не потокобезопасный, что делать в этой ситуации? Создавать новый экземпляр при каждом запуске, или вообще реализовать кеш? Функция ProcessImage запускается асинхронно через Task.Run в ASP.NET
public class ImageProcessor() { public ImageProcessor() { var options = new ImageSettings(); options.Format = ImageFormats.JPEG; }
public MyImage ProcessImage(MyImage image) { var converter = new ImageConverter(); // Не потокобезопасный return converter.Convert(image, options); } }
public static class ImageProcessor() { public static MyImage ProcessImage(MyImage image) { var converter = new ImageConverter(); return converter.Convert(image, new ImageSettings(ImageFormats.JPEG)); } }
Как же жопа горит от либы AngleSharp, ее разрабы настолько ебнулись на почве расширяемости и абстракций, чтоб без документации под боком и десятка кастов пользоваться ей невозможно, ведь каждый метод возвращает ебучий интерфейс с минимум функционала.
>>3255590 ох уж эти рейтинги а реальность такова что либо на жаве сидят деды в легаси (ну то есть уже написано что то на жаве) либо не написано но жавоеды "нихатим ничего изучать мы долбни" иначе же жаву активно двигает котлин хотя как бы не заставляют
>>3255590 Ты же даже не жавист, в чем смысл заниматься такими унылыми вбросами? Все адекваты понимают, что жава популярнее, там больше вакух и сытнее зепки. Я бы перекатился, но я слишком ленив, чтобы изучать что-то после работы. Уже 2 года дома не программирую.
>>3255590 Ну, по этому рейтингу - жава с проглотом у питона сосет. Че дальше-то?
Суть. Для разработчика. Жава литерли шарп, но хуже во многих аспектах. Многие вещи - нелогичны или криво задизайнены.
Проблема шарпа очень долго была в том, что он был заперт на винде, а Mono крайне медленно развивался по понятным причинам.
С точки зрения рынка. Вакухи на жаве - это 99% легасиговно, в котором ты будешь с Ant ебаться, или еще какой-нибудь древней залупе, потому что ПАРУ РЕЛИЗОВ пропустили, потом - боялись сломать обратную совместимость, а теперь - переход на современный стек жавовский по трудностям сравним с написанием с нуля не про код приложения, а про то чтобы все это говно просто запустилось, особенно когда использовалась какая-то библиотека древняя, которая вот на этой версии жавы работает, а вот на новой - с какого-то хуя не работает, и да, такой хуйни навалом, особенно если это был какой-то десктоп проект на жаве.
На шарпе, если не вляпываться в десктоп - дохуя проектов на современном стеке, с современными технологиями. Сам язык - дизайнили нормальные люди, а потому - почти каждая фича в тему, и пользоваться ей приятно.
По ЗП, в реальности - +- разрабы получают. Разница на уровне сенек - сопоставима с погрешностью, и не стоит того, чтобы перекатываться на другой стек.
Вот питон - да, база. Но там сеньеры с 1 годом опыта, которые в принципе не представляют, что такое многопоток, перформанс, и вообще, полный треш. Но сам питон - мегабаза, лучший язык для всего, если перформанс не важен.
>>3255819 Ничего удивительного. Шарп пилят натуральные макаки, они не способны на что-то большее, чем добавление очередного сахарка. Какие уж там оптимизации сборки мусора
>>3255819 за все нужно платить. любые оптимизации это плюс к пожиранию памяти. дотнет вот притащил GC DATAS и новые lock типы они тоже направлены именно на уменьшения потребления памяти
а жаву сколько не корми им плевать. память ом ном ном.
>>3255823 в шарпе меньше мусорят так то. потому и чистить нужно намного реже. Это вам не жава где мусора столько что ПРИХОДИТСЯ чистить ее и вот ваши 1мс превращаются в "много раз по 1мс"
>>3255090 >Ты дурак? А может ты пидор? Вот смотри, глобально же нет разницы как делать так \{ или так {{. Но если сделать так \{, то компилятор даст ошибку, ибо не знает такой последовательности. Так вот всё что нужно было сделать это прописать в компиляторе пропускать последовательность \{ без изменений. И вопрос был бы решён, был бы единый общий подход к экранированию, без этой {{ херни.
Ну ладно, как есть так и есть, мой вопрос собственно в другом. Мне надо распарсить текстовый файл, содержащий помимо латинских слов ещё и кириллицу, файл в аски-кодах. Я тут узнал что char и string оказывается двухбайтовые и работают в уникоде. Ещё прифигел когда узнал что можно давать названия переменным русскими буквами. Попытался считать из файла несколько символов кириллицы и вывести в сосноль, закономерно увидел ????. Как быть? Наверно сконвертировать одно в другое и обратно можно?
>>3255783 > Но сам питон - мегабаза, лучший язык для всего, если перформанс не важен. А что там по UI? Чет я смотрел, и там возможности скуднее винформсов.
> As for why async methods don't support out-by-reference parameters? (or ref parameters?) That's a limitation of the CLR. We chose to implement async methods in a similar way to iterator methods -- i.e. through the compiler transforming the method into a state-machine-object. The CLR has no safe way to store the address of an "out parameter" or "reference parameter" as a field of an object. The only way to have supported out-by-reference parameters would be if the async feature were done by a low-level CLR rewrite instead of a compiler-rewrite. We examined that approach, and it had a lot going for it, but it would ultimately have been so costly that it'd never have happened.
Не знаю, где еще спросить. Мне нужно в С# коде юзать апи Yices, которое на С. В частности, там есть функция: int32_t yices_get_unsat_core(context_t ctx, term_vector_t v) Причем term_vector должен быть инициализирован другой функцией из этого апи: void yices_init_term_vector(term_vector_t v)
Сам терм вектор это просто typedef struct term_vector_s { uint32_t capacity; uint32_t size; term_t data;//alias int32_t } term_vector_t; Мне собственно, нужен этот массив интов, думаю. Как адекватно это делать? Создать стракт в шарпе и маршаллить в него? Как адекватно его создать, у меня пока что-то такое: [StructLayout(LayoutKind.Explicit, Size = 12, Pack = 4)] struct term_vector { [FieldOffset(0)] private uint capacity; [FieldOffset(4)] private uint size; [FieldOffset(8)] private IntPtr data; } Но я видел, что вроде поля как-то нужно помечать, если в них маршаллить из unmanaged памяти что-то хочешь. По теме я нашел пару похожих вопросов в инете, но там уродски написано, не понял, если знаете где более-менее объяснили это, то скиньте пожалуйста
Всем примет, из-за чего появляется такая ошибка (DT1001failed to solve: failed to compute cache key: failed to calculate checksum of ref a396842d-1618-4563-93d7-d0dd385a7a0b::h5l6xy7366kql0pok826btsgq: "/Company.Domain/Company.Domain.csproj": not foundIf the error persists, try restarting Docker Desktop.), когда я запускаю через docker-compose. Если запустить просто как Сontainer(Docker) то всё нормально работает, а в составе docker-compose нихуя. Пробовал файлик докера прокидывать выше к .sln, но это тоже не сработало.
>>3256240 По-моему, буквально, твой пример: https://learn.microsoft.com/en-us/dotnet/standard/native-interop/type-marshalling#marshalling-classes-and-structs И у тебя будет что-то типа: void yices_init_term_vector(out term_vector v) int yices_get_unsat_core(context_t ctx, ref term_vector v) (как я понял ctx это просто opaque pointer, так что вставь нужный тебе pointer-sized тип который нормально маршаллиться: void или IntPtr/nint) [StructLayout(LayoutKind.Sequential)] public unsafe struct term_vector { public uint capacity; public uint size; public int data; }
А вообще, так как я маршаллинг практически не знаю, я бы сделал так (если я правильно понял API): int yices_get_unsat_core(void ctx, term_vector v); void yices_init_term_vector(term_vector v); public unsafe struct term_vector { public uint capacity; public uint size; public int data; } (хотя ctx можно заменить на какую-нибудь простую обёртку над void*/IntPtr, и она будет нормально маршаллиться без каких либо телодвижений). Ну обращаться к данным можно как: new Span<int>(v.data, checked((int)v.size))
>>3256349 Вот оба варианта скриншотом (из SharpLab'а).
И что-то я не нашёл как маршаллить массив переменной длины внутри структуры из unmanaged в managed (может и можно как-то через LibraryImport и кастомные маршаллеры, но я давно привык пердолиться ручками и эти новые штуки я даже не пробовал. Может тут, в треде, есть эксперты маршаллинга и они знают как?).
>>3255923 >Encoding.UTF8.GetString >Encoding.ASCII.GetString Во-первых, почему UTF8 когда уникод двухбайтовый? Во-вторых, они не могут в кириллицу.
Давай расскажу подробнее что мне надо. Вот есть у меня файл тхт.тхт, кодовая страница 1251, следующего содержания на самом деле значительно сложнее, но пока так qwerty йцукен
Мне в нём надо искать разные подстроки, считать количество букв в словах и тд. Почти все эти задачи реализованы в String. И вот чтобы не пердолиться, тоже самое самому не писать, а применить уже имеющееся, я копирую содержимое файла в строку string DumpFile = File.ReadAllText(тхт.тхт);
Так вот все латинские буквы оно конвертирует автоматически, получается как-то вот так 0х0069, 0х006Е, 0х0069,0х0065, а вся кириллица переходит в 0х003F, 0х003F, 0х003F, короче знак вопроса. Если вывести на экран qwerty ??????
И никакие string DumpFile = File.ReadAllText(тхт.тхт, Encoding.ASCII); и Encoding.Convert(Encoding.ASCII, Encoding.Unicode, DumpFile); не помогают. Ничто из этого не может в кириллицу, результат один - вопросики.
Можете пояснить, что заставляет freezable-коллекции вызывать событие Changed при изменении свойств их итемов? Я пытаюсь повторить, но у меня ноль реакции.
Я думал, что freezable-объекты автоматом будут это делать. В MDSN написано, что если класс не содержит DependencyProperties, то нужно самому позаботиться об обновлении, но ни WritePreamble(), ни WritePostscript() эффекта не дали.
Я банально копирую вот эти три метода и толку ноль: public void Add(T item) { AddHelper(item); }
private int AddHelper(T value) { int index = AddWithoutFiringPublicEvents(value); WritePostscript(); return index; }
internal int AddWithoutFiringPublicEvents(T value) { int index = -1;
WritePreamble(); index = ((IList)_collection).Add(value);
++_version;
return index; }
Подозреваю коллекцию _collection странного типа FrugalStructList которая волшебным образом отслеживает изменения итемов, но в чем тогда смысл городить freezable-коллекции?
>>3256947 Что мог то смотрел, с чатжпт ничего не копипастил. У меня вот эти три книжки есть, оттуда и брал. Не забывай я - нуфаг, много от меня не требуй, лучше покажи как делать.
В .NET Core 3.0 добавили CallerArgumentExpression аттрибут. В .NET 6 начали его поддерживать. И только в .NET 9 они приклеили это к Debug.Assert() (с помощью OverloadResolutionPriority).
/// Extenders of Freezable must call this method at the end of an API which /// changed the state of the object (e.g., at the end of a property setter) to /// raise the Changed event. Multiple state changes within a method or /// property may be "batched" into a single call to WritePostscript(). ///
>>3257092 >никакой магии Так вот нихера не происходит. Я тебе привел в пример кусок кода, где используется WritePostscript при добавлении итема.
Вот смотри. Есть майкрософтовский freezable-класс GradientStop, в котором есть два DP свойства: Color и Offset. Есть freezable-коллекция GradientStopCollection, которая хранит в себе элементы типа GradientStop.
Так вот, если я в одном из добавленных итемов GradientStop изменю значение свойства Offset, то это вызовет собите Changed сперва у GradientStop, затем у GradientStopCollection.
А вот у моей кастомной коллекции, где используется данный код >>3257087 при изменении Offset не возникает события Changed. Это событие возникает разве что при изменении самой коллекции, например в выполнении метода Add. И вроде как логично, ведь этот метод запускает WritePostscript().
А магия заключается в том, что что-то где-то в коллекции чекает изменение СВОЙСТВА итема этой коллекции , но никаких подписок я не нашел. Если не понятно, то я могу скинуть проект.
>>3257094 >при изменении Offset не возникает события Changed И чтобы уточнить. Сам экземпляр GradientStop при изменении Offset вызывает событие Changed. Но вот моя коллекция это событие не детектит, и соответственно не вызывает свое событие Changed.
>>3257094 Ты небось ищешь подписку коллекции на итемы стандартными методами Я хз как там на самом деле но если глянуть по диагонали твою же градиентстопколлекцию, то в глаза бросается вызовыOnFreezablePropertyChanged( который в свою очередь вызывает context.ProvideSelfAsInheritanceContext
И точно так же и отписывается через OnFreezablePropertyChanged
>>3257286 >иначе ж в этом тексте хрен куда перейдешь. В source.dot.net обычно можно, там все кликабельное, но есть элементы для которых ссылка отсутствует, либо ведет на пустую страницу.
Почему в ef core я не могу сделать так? Library.Books.Add(new BookLibrary(){ Library = Library, Book = new Book() }); Приходится сначала добавлять в DbSet книгу, и только потом добавлять промежуточный класс с ней, иначе ошибка FOREIGN KEY что-то там.
Внимание вопрос. Как из функции вернуть несколько значений? В старом добром Си я бы передал в функцию сколько нужно указателей и через них вернул бы значения. А тут как? Тут нет указателей же.
>>3257675 Тебе уже 10 раз пояснили. Возьми нужную кодировку и прочитай файл с ней. Что не понятно? Могу тебе даже запрос в гугл составить: c# read file with encoding
>>3257664 - ref/out - создаешь структуру с каким угодно количеством параметров и возвращаешь ее. Для ленивых придумали кортежи (их два вида), которые под капотом автоматически делают что-то типа структуры или класса (в зависимости от вида). Еще есть анонимные типы — их использовали до кортежей.
>>3257822 Не знаешь что такое синдром утенка и "со своим уставом в чужой монастырь не ходят"? Выросло поколение зумеров блин, классики не знают.
Пиздец это тащить в новый яп привычки со старого. такое иногда можно встретить. Приходит какой нибудь абстрактный жавист или пхпэшник в питон и начинает срать на стиль (вон в питон есть даже стандартный модуль логгинг, где стиль отличается от питонического) и плодить абстракции ради абстракций, которые в питоне нахрен не надо.
Пхп так вообще клинический случай в своем рождении - сборище функций, где каждый пилил "а мне так удобно вот идите нах"
Точно так же в шарпе out параметры являются только лишь непривычными для тех кто пришел откуда то, а не неудобными или еще как.
Давай еще повсеместные TryGetValue(..., out var ) в кортежи оборачивай. Ну типа так тебе удобнее.
>>3257869 да. используй списки List<KeyValuePair<TKey,TValue>> и ищи в них последовательно. Как нашел - выдавай кортеж. Кстати, если сделать один список на приложение, то GC напрягаться не будет. Экономия. Крайне рекомендую
Ковыряю шарп и раст на скорость. Имеем List<byte[]> миллионы итемов и идет по ним поиск. Само собой привет HashSet, но это все же память, да и byte[] это аллокации.
Уменьшаем память - сортируем, склеиваем все в один большой byte[] и пишем бинарный поиск. Сравнение элементов не пишем, ведь есть arry.Slice(...).SequenceCompareTo(..) Все работает, на 25% медленнее HashSet, что ожидаемо.
Ради изучения раста пилю то же самое на расте 1 в 1 и бенчмаркаю (миллионы элементов поэтому время само собой относительное) шарп (HashSet) - 211 ms шарп (бин поиск) - 287 ms rust (бин поиск) - 252 ms
конечно в rust есть еще simd, но это еще нужно с ним как то приседать. А в шарпе присели за меня.
>>3257817 В чем дрочь? В анрил энжине в С++ в норме вещей, когда метод возвращает структуру, если возвращаемых значений несколько. Передают по указателю только 1-2 элемента. Да даже два много. В шарпе ровно та же система, только навалили сахарку, чтобы ты с созданием структур не ебался.
>Я проще массивы одноэлементные объявлю. Одноэлементный это типа одномерный? Глупость какая-то. Обосрешься т.к. несколько итемов будут иметь разные типы. Ты в object собрался их пихать? Не дури и возвращай структуры как отцы в С++, а если ленивый, то возвращай кортежи.
>>3257872 Если самому список держать, то нет смысла KEyValuePair хранить, лучше именованный кортеж. Правда мне часто обновлять значение надо, неудобно наверное кортеж пересоздавать.
Видел как выглядит словарь? Он хранит три списка: один для ключей, один для значений и один для хеш кодов (это чтобы по ключам не искать). А ключ-пару словарь создает только когда ты от него это просишь, например когда пытаешься использовать словарь как список. Словарь изначально не содержит в себе KeyValuePair, это создается на ходу при запросе.
>>3257942 >Как не задолбаться в этой ситуации??? Иметь структуру или класс в качестве элемента.
Dictionary в себе содержит список структур типа Entry: private struct Entry { public uint hashCode; public int next; public TKey key; // Key of entry public TValue value; // Value of entry }
>>3257959 Двачую этого господина. Вот, например, яндекс диск для синхронизации файликов кушает почти гигабайт. А что такого? У юзера оперативы 32Гб, ему жалко что ли? Ну и что, что он только запустил комп, а у него уже нет 30%? Делать из этого трагедию?
Ребзики, у меня есть жиссон на миллион объектов (не иронично и буквально). Как эти объекты аккуратно записать в бд? И перед этим для каждой ещё проверить существует ли в бд связанная сущность и получить ее айдишник для вставки, если нету не вставлять. Какое оптимальное решение по соотношению скорость/не положить сервер? Если делать это все последовательно одним дбконтекстом, он же охуеет этот миллион сущностей отслеживать да и долго это наверное. Если распараллелить охуеет уже сервер от миллиона коннекшеннов от индивидуального контекста для каждой сущности у него же максимум 32 тыщи. Пока мое решение состоит в параллельно запускаемом асинхронном методе который получает вставляемую сущность, проверяет для неё наличие связанной и вставочки если все в порядке. Но при этом вызывающий этот метод код делает паузу на 10 сек после каждой параллельных 1000 вызовов. По моим прикидкам предыдущее вызовы должны заваешиться и созданные контексты должны релизнуть коннекшены. Но мне сыкотно это запускать. Может существуют способы получше? Ну или хотя бы морально поддрежите
>>3257721 Вот тебе лучей бобра за конкретный пример. Осталось непонятным зачем нужна строчка 9, у меня на неё компилятор ругается, такие имена не знает, а код адекватно работает и без неё.
>>3258558 Это сделано когда кодировки тянутся из нугет пакета. Всякие закорючки и прочие копролиты кикнули в него. В фреймворке на сколько помню всё сразу было в стандартной поставке
>>3258559 Ну я добавил эту строку не ради красного словца, а потому что без нее ругалось и не работало. В этот раз не пришлось ставить пакет с нюгета как раньше, но без строки не заработало.
>>3257666 >>3257809 >ref, out Ну похоже это то что надо. >Кортежи Не взлетели. Может из-за того что у меня вижуал студия 2013 старая?
>>3257809 >создаешь структуру с каким угодно количеством параметров и возвращаешь ее. Городить структуру ради двух переменных это какое-то извращение ради извращения. >Еще есть анонимные типы — их использовали до кортежей. Загуглил на скорую руку, с наскока ничего не понял, может позже к этому вернусь.
>>3257832 >А возня с указателями типа не дроч? А в чём тут дроч?
>>3257840 >Не знаешь что такое синдром утенка и "со своим уставом в чужой монастырь не ходят"? >Выросло поколение зумеров блин, классики не знают. Я так то скуф уже. Но про утёнка не знаю, да. А про устав ты говоришь в контексте что я с ним куда-то лезу, я я никуда не лезу, вот я тебя и не понял. Я всего лишь зашёл спросить как тут люди без указателей живут. Оказывается какое-то подобие указателей таки есть.
>>3257919 >В чем дрочь? В анрил энжине в С++ в норме вещей, когда метод возвращает структуру, если возвращаемых значений несколько. Передают по указателю только 1-2 элемента. Да даже два много. Не знаю как там в анрыле, может там специфика такая, но я даже ради пяти элементов структуру не буду делать. Это же надо её объявить, имя придумать, и всё только ради чтобы применить один раз. >Одноэлементный это типа одномерный? Нет это типа int[] A = new int[1]; Работает чётка. И ref/out уже не нужны.
>>3258572 >Нет это типа >int[] A = new int[1]; А смысл заключать один элемент в массив, когда ты можешь и так вернуть один элемент? Представляю какой у тебя бардак в коде, когда метод принимает условный массив из нескольких элементов и правит их по индексу. Учитывая твою лень, там еще и документации нет, лол.
>может там специфика такая В анриле в норме вещей возвращать комплексные данные, типа матриц трансформаций, или элементов инвентаря. Создают структуры пачками и не бухтят. Но за пределами игростроя я редко встречаю задачу, когда мне необходимо возвратить много не связанных между собой значений, которые применяются один раз. В большинстве случаев это намекает на то, что метод перегружен функционалом и берет на себя слишком много задач.
>я даже ради пяти элементов структуру не буду делать. Это же надо её объявить, имя придумать, и всё только ради чтобы применить один раз Организованность должна быть. Если твои функции шатают 5 и более параметров по ссылке — это же пиздец какой-то даже в плане читаемости кода. Я пользовался методами WinApi, которые написаны на С++, и не встречал чтобы по ссылке принималось больше чем один объект. Даже условный метод получения координат курсора требует ссылку на одну POINT структуру, а не две ссылки X и Y. >BOOL GetCursorPos( > [out] LPPOINT lpPoint >);
Хз по каким говнокурсам ты учил С++, но что-то явно не так.
>>3258683 Что за вопросы? Очевидно что: (затраченное время * коэффициент опыта)
>По строкам кода Только если ты индус. Можно сказать "а что мешает мне навалить кучу строк?" или "что мешает мне затягивать время?". Но если речь идет о добросовестном исполнении, время может тратиться и на другие вещи, помимо кода, поэтому оно более содержательно.
>По функционалу программы? Ты будешь держать таблицу всех возможных вариантов функционала с прайсом? Если у тебя уже готов конвейер с готовыми решениями, то может такой подход и имеет смысл.
>>3258846 >>3258835 Ну я просто хз как я беру по рынку или нет. Я оцениваю примерно по затраченному времени ну и если функционал прибавляется то и время прибавляется. В основном мелочь делаю, тг боты регеры парсеры 100-200$ вот хуй знает это по рынку или нет. Как то клиент говорил что уже заказал бота 50$ ему мозг месяц ебали в итоге все криво работает и с ошибками. Я сделал за 180$ за неделю. Не ну так то за 30 часов наверное сделал, просто неделя ушла на переспросы и ожидание ответов.
>>3258572 я отвечал тому кто написал >Я проще массивы одноэлементные объявлю.
А так... >Городить структуру ради двух переменных для этого же есть туплы всех видова размеров цветом и с подогревом
>Я всего лишь зашёл спросить как тут люди без указателей живут да так же как и без goto - не особо знаем куда пихать goto и указатели если и без них норм.
>>3258899 >туплы Не знаю что это. >без goto Ну так-то goto иногда удобно.
>>3258648 >Хз по каким говнокурсам ты учил С++, но что-то явно не так. Я - не вы, чтобы по говнокурсам учить. Я в шараге учил, ну и сам в основном.
>Учитывая твою лень, там еще и документации нет Какая документация, о чём ты? Я софтину почти для собственных нужд пишу.
>А смысл заключать один элемент в массив, когда ты можешь и так вернуть один элемент? А мне надо несколько, притом разнотипных. Вот я и объявляю несколько разнотипных одноэлементных массивов и передаю их в функцию/метод.
А я смотрю вы тут #-холопы все какие-то зашоренные сидите. Склонитесь же перед Си-господином.
>>3258852 >просто неделя ушла на переспросы и ожидание ответов. А это тоже часть работы. >>3258852 >Я сделал за 180$ за неделю. Если экстраполировать, то в месяц это получится тысяч 70...80 руб. По сути зарплата джуна в мелкоконторе. И нахуй нужен такой фриланс?
>>3259390 >А мне надо несколько, притом разнотипных. Вот я и объявляю несколько разнотипных одноэлементных массивов и передаю их в функцию/метод. Ты ебанутый? Чем тебе Tuple (кортеж, уточнение для одаренных) не угодил? Что за тупейший дрочь с массивами размерностью в один элемент? Учись делать вещи правильно сразу же, а то потом будет тяжело переучиваться >Я - не вы, чтобы по говнокурсам учить. Я в шараге учил, ну и сам в основном. >Склонитесь же перед Си-господином. Т.н. "Си-господин", c богатым опытом программирования в целых ДЖВА(!!!) проекта lab1|lab2, которому хватает ума чтобы делать все, кроме того что ему советуют (а именно использование Tuple/специальной структуры/ref-out), предлагаю Вам вернуться в Вашу проф. среду и в ней и остаться, коли Цэ Решетка не удовлетворяет Вашим изысканным требованиям
>>3259440 >чтобы делать все, кроме того что ему советуют (а именно использование Tuple/специальной структуры/ref-out) Ты жопой читаешь или у тебя память девичья "кому дала не помню" забыл, что тремя постами выше было? >>3258572 >>ref, out >Ну похоже это то что надо. >>Кортежи >Не взлетели. Может из-за того что у меня вижуал студия 2013 старая?
>целых ДЖВА(!!!) проекта lab1|lab2, Нибамбит что у кого-то есть вышка, а у тебя нет?
>>3259468 >Не взлетели. Может из-за того что у меня вижуал студия 2013 старая? всё. бросай. если у тебя не взлетают вещи которые, ну ок нет поддержки редактора для краткого синтаксиса, но в полном это просто примитивные дженерик классы/структуры, то значит тебе нужно еще 10 высших.
>>3258624 В С/С++ так. А это аргумент. Вы же тут все так любите вашу модную инкапсуляцию. Вот это оно и есть, хоть и не ооп. Я создаю блок { }, объявляю там свои переменные и развлекаюсь с ними как хочу. Почему я должен согласовывать их имена с остальным кодом?
>>3259467 >Я же не смогу играть на работе в пое Так ты и сейчас не можешь. Ты 30 часов за неделю потратил на работу, это практически и есть стандартная рабочая неделя (если из неё вычесть всяческие проебы времени).
>>3259474 >В С/С++ так. А это аргумент. Аргументация "В моем языке так, хуле во всех остальных не так" - это сильно. >>3259474 >инкапсуляцию Она тут с какого бока? >>3259474 >Почему я должен согласовывать их имена с остальным кодом? Потому что гладиолус https://metanit.com/sharp/tutorial/2.18.php
>>3259474 >в языке <name> вот так, а значит должно быть везде так ну и пиши на языке <name>, какая проблема то. Ведь там есть привычное синдромоутятное
>>3259468 >Ты жопой читаешь или у тебя память девичья "кому дала не помню" забыл, что тремя постами выше было? >ну ref-out подходит но все равно не буду их использовать. "Зачем мне специальные конструкции конкретного ЯП которые как раз были созданы под моего рода нужды если можно ебаться с массивами?" >VS 2013 Установить поновее ума нехватает или что? Слишком много кнопок надо нажать чтобы это сделать? Ты бы еще использовал самую первую версию дотнета/шарпа и говорил бы "ой, а почему у меня нету дженериков? Си Шарп говно что ли? Мда, а вот в крестах...". Даже если у тебя какая то острая необходимость ввиду чего-либо использовать только 13ую студию, у тебя есть еще целых два варианта решения своей проблемы.
>Нибамбит что у кого-то есть вышка, а у тебя нет? Интересное конечно предположение, жаль только ошибочное. То был жирный небольшой намек на то, что ты делал по учебе и близко не стоит к тому как на самом деле пишут код сейчас на Си/Си++. Но зато да, ты определенно теперь знаешь как работают указатели, эт ты молодец. Можешь гордиться, только не зазнавайся.
>>3259390 >Какая документация, о чём ты? Я софтину почти для собственных нужд пишу. Вот ты даже не понимаешь значения документации. Каким боком "для себя" оправдывает её игнорирование? Фразы "для себя" и "у нас не экзамен" используют только опущи с тремя классами образования. Для себя делают хорошо, но у долбоебов принято для себя делать спустя рукава.
>Я - не вы, чтобы по говнокурсам учить. Я в шараге учил, ну и сам в основном. Еще хуже. Если в шараге такому учат, то там явно отсутствует контроль качества. Инфоцыган можно хотя бы в интернете хуями забросать и понизить им рейтинг, а твой говновуз закрыт от внешнего взора, и кто выходит из него — те кончи с ЧСВ, не отдающие отчета в своих действиях.
>>3259468 >>Не взлетели. Может из-за того что у меня вижуал студия 2013 старая? Кроме кортежей тебе предлагали анонимные типы >>3257809 Они использовались до появления кортежей. Менее удобные, но в твоем случае выбора особого нет.
Если я привязываюсь к объекту типа Freezable, то изменение его свойств во вьюхе, автоматически обновляет все остальные привязки к этому объекту, если они были.
Но если я привяжусь к свойству (не важно какого типа) через конвертер, который в результате конвертации возвращает экземпляр Freezable объекта, то попытка во вьюхе изменить его свойства, не обновляет привязки.
Причем я пытался привязать к результату конвертации два контрола, и если я в одном контроле меняю содержимое Freezable объекта, то другой контрол это фиксирует. Но вот у самого конвертера не срабатывает метод ConvertBack, и не происходит изменение свойства во вьюмодели.
Допустим я пишу программу для работы с графикой, в которой есть слои. Как сделать так, чтобы при перерисовке одного слоя, остальные не перерисовывались сейчас при рисовании все слои последовательно рисуются на выходном холсте, который уже рисуется в гуи? В целом есть идея разместить каждый слой в виде отдельного контрола, которые будут накладываться друг на друга, тогда в теории гпу будет перерисовывать только его. Но хочется все же добиться подобного эффекта не полагаясь гуи.
>>3260000 работай с биндингами из кода и все поймешь.... ....поймешь что нихрена не понять как оно устроено Потому что биндинг это не цепочка "источник - таргет", а просто один биндинг. И если тебе нужно прервать одну цепочку то ты не можешь ибо нет никакой цепочки. Ты рушишь весь биндинг сразу. Понять где там источник где таргет....сам черт ногу сломит.
>>3260016 > Как сделать так, чтобы при перерисовке одного слоя, остальные не перерисовывались Меняю на этом слое цвет одной точки на прозрачный, твои действия?
>>3260363 Нижний слой может и не изменится, но станут видны те его элементы, которые раньше скрывал верхний слой. Конечно же, их нужно теперь рисовать. Самый простой способ - перерисовать нижний слой и поверх него уже верхний. Но загвоздка в том, что у нижнего слоя тоже могут быть прозрачные элементы, за которыми видно цвета с ещё более низких слоёв, так что просто запросить цвет из одного нижележащего слоя не получится, будет по меньшей мере итерация до самого низа, и это на каждую точку с альфа-каналом меньше 255, причём надо ещё и учитывать разные эффекты смешивания цветов. Может, это можно как-то оптимизировать, если перерисовка всех слоёв - супер дорогая операция (т.е. реально возникли проблемы производительности, а не просто теоретические рассуждения). Но для начала надо оценить, насколько дешевле будет вычислить все перекрытия и подготовить "дифф", тут попутно и другие нюансы могут возникнуть. Похожую проблему решают в 3D-графике с Z-buffer, наверняка там есть какие-нибудь трюки, чтобы работало быстрее. Охуеть простыня получилась
Я ненавижу десктоп, нахуй. Какого хуя там дедлок на дедлоке? Еще и это. Типа, блядь. Код-то не я писал, а мне - вычесывать это. Короче. Да. Десктоп - могила. ВЕБ - сила.
>>3260466 дык я и предложил. не перезванивать. обновлять все слои на каждый чих это тупо. Взять тот же WPF - ему тыща лет, но даже он не обновляет то, чего не видно.
>>3260474 Ну. МБ дело в том что в вебе я один работал. За все время работы в вебе - всего один дедлок был. А тут - рил, буквально на каждом шагу. Или еще веселей, не в том потоке обновил визуалку - КРАШ, нахуй. Не в том потоке обработал - КРАШ, нахуй. Короче. Мне как-бы и нравится что не просто жсоны гоняешь, а КАК В КНИЖКАХ, ОРХЕТЕКТУРА, ВСЯ ХУЙНЯ. Но чет выглядит это все оч странно.
>>3260404 Хм, я думал, что нижний слой хоть и не виден, но хранится в памяти видеокарты. И при формировании итогового изображения которое выводится на монитор, все хранимые в памяти изображения отдельных элементов просто последовательно накладываются друг на друга и отрисовываются и выводится результат. Я не прав?
>>3260613 Проделывал. Подводные - надо перестать писать говнокод. Больше людей понимают, что ты пишешь, а потому могут и спросить. Много чего учить надо. За велосипеды дают пиздюлей. Работу найти проще. Платят, в среднем, больше.
>>3260629 Ну буквально постов 20 выше был чел, который в C# искал аналог указателей C++ для передачи параметров в метод и пришел к решению заворачивать каждое значение в массив. За такое в C# сообществе стреляют в упор, потому что есть специальные вещи для таких задач.
Хочу учить с# вначале для десктопа, бекэнда, а потом перекатиться на разработку игорей, т.к думаю с играми вряд-ли сразу что то получится: не развито и очень мало вакух... или я ошибаюсь?
Какие книжки посоветуете для начала?
Или мне стоит учить только то, что требуется в вакансиях на ХХ для стажеров/джунов? Как адекватно это воспринимать, если количество необходимых условий или навыков "слишком" много/мало в вакансии? Нужен отдельный ноут с линуксом?
Поступил на заочку околопрограммисткую, т.к уже заканчивал магу по другой специальности. Диплом и 2 статьи пилить... по ит для меня это новое и выглядит довольно странно( хотя и в теплотехнике формул хватало из книжек 20-50 летней давности) мне 31
>>3260857 >Хочу учить с# вначале для десктопа, бекэнда, а потом перекатиться на разработку игорей Звучит как "хочу начать учить сразу две разные профессии, чтобы потом перекатиться в третью". Это все разные специализации, требующие разных знаний. Там хорошо если процентов на 30% идет пересечение и переходя из одной в другую приходится дофига чего забывать и учить новое.
>Какие книжки посоветуете для начала? Албахари
>>3260857 >Или мне стоит учить только то, что требуется в вакансиях на ХХ для стажеров/джунов? Выбираешь нужное направление, ищешь более-менее нормальный роадмап по нему и учишь. На вакансии ориентируешься уже когда хоть какой-то опыт будет.
>>3260857 >Нужен отдельный ноут с линуксом? Нет. Хватит виртуалки или wsl. Для веба знание линукса будет в плюс.
>>3260857 >Поступил на заочку околопрограммисткую, В первую очередь на учебе нарабатывай связи и выходы на стажировку/практику. Все остальное вторично.
>>3260531 Смотря как использовать видеокарту. Если делать простую рисовалку 2D-графики на каких-нибудь винформах, видеокарта не узнает ни о каких слоях, для неё будет тупо готовая текстура, которую надо отрендерить, а все вычисления слоёв будут делаться на CPU. А можно через OpenGL/Vulkan/DirectX создать 3D-сцену с несколькими прямоугольниками по одному на слою, к ним уже привязать содержимое соответствующих слоёв, навесить пачку шейдеров, и тогда всеми вычислениями будет заниматься видеокарта, которая сама волшебным образом поймёт, что нужно перерисовывать, а что не нужно, а работать будет быстрее.
>>3261199 Спасибо за ответ, мне бы и в голову не пришло смотреть в сторону 3д графики для реализации подобного. Кем ты работаешь, если не секрет, что такими специфическими знаниями обладаешь?
>>3261011 >Албахари Там в общих чертах, лучше на инглише? Я понимаю текст, но не могу уверенно на языке говорить. > Выбираешь нужное направление, ищешь более-менее нормальный роадмап по нему и учишь. На вакансии ориентируешься уже когда хоть какой-то опыт будет. Опыт разработки? Что мне говорить... когда я не работал уже 1.5 года. А что в первый раз по другой профе? > Нет. Хватит виртуалки или wsl. > Для веба знание линукса будет в плюс. Хм. Может есть список вещей, которые нужно сделать или по необходимости это всё потом устанавливать/изучать? > В первую очередь на учебе нарабатывай связи и выходы на стажировку/практику. Все остальное вторично. Да я хз если честно. Одногрупники(всего 5 штук) занимаются php или 1с-битрикс. И разговаривают неохотно. Они уже работают по профе, т.к бакалавра уже проходили, либо в ип работают кабанычем. Или преподов по этому вопросу подергать? >>3261062 > сразу выбирай либо бэкенд либо игры. > Среди них очень мало пересечений между друг другом. Значит игры... но это мне придётся ориентироваться на запад сразу? Или есть какая работа и в РФ?
>>3261484 ладно бы жава, мобилки, шарп, питон - ну чтобы покрыть все направления, авось куда то устроится, начать поднимать бабло и уже тогда учись куда хочешь.
с++ то зачем. тонну времени потратишь
какая же дурная капча. для решения ее с помощью ботов самая простая )))
>>3261495 > ладно бы жава, мобилки, шарп, питон - ну чтобы покрыть все направления, авось куда то устроится, начать поднимать бабло и уже тогда учись куда хочешь. А как же конкуренция? Всё кроме шарпа перенасыщены... хотя тот же шарп, слышал, увядает
>>3261504 Тут все зависит от места жительства (хотя ковид немного подправил ситуацию в правильное русло). Я в свое время вообще с руби начинал, потому что брали без знания вообще (ну то есть приходишь и говоришь - я котик у меня лапки и я ничего не знаю) и платили со старта 800 пока тебя обучают. Все относительно. Вон тот же руби как по мне загнил давно, но люди работают и получают очень даже хорошо. Так что многое зависит от что оно, где оно и откуда бабки берет.
А щас меня десктоп кормит. Причем кормит уже больше 10 лет. Но это не значит что на десктопе "пошел и нашел работу".
>>3261507 Жаль курсов бесплатных нет по тем прогам. На сайте трудоустройства по безработице смотрел - там тоже 1с один. А так бы сходил для ознакомления. Ладно, пока Албахари скачал. По английски новые термины непонятны, думаю разберусь
>>3261528 Значит вкатываться нужно было в 2014 году? Я нихера ничего не понимал в это время Мне было... 20 что-ли Думал такой буду проектировщиком, а как попал на работу в 25 - охуел с того насколько я там не нужен и это ужасно скучно для меня Зато есть БАЗА. Чего не скажешь о наличии базы с ИТ
>>3261590 пока ты ищешь волшебные уроки/курсы - ничего не выучишь. так и будешь искать. Потому что а) мозг ищет волшебную таблетку б) у каждого свое восприятие. Даже когда станешь спецом, то посмотри ролики для начинающих по любым темам - удивишься как 90% "непонятно вещают хрен научишься"
учиться нужно в работе. Прочитал по диагонали книжку или статьи плевать какие, хоть на метаинит и вперед делать что то. Спрашивать, гуглить, переделывать - так приходит понимание и закрепление. Так что если хоть что то умеешь - сразу начинай писать рабочий проект. Пусть даже ты его выбросишь или 100 раз перепишешь.
>>3261590 забыл добавить главное - найди наставника. Гуглить конечно здорово, но быстрый фидбек "тут не так а так" просто бесценен. Ибо перебирать варианты "а можно закодить так" можно, но долго.
>>3261668 нет. просто полиглот все что используется - обучается все, что не используется - забывается. концепции и парадигмы важнее знания языка, а они нарабатываются только в реальных проектах. проблема в поиске реальных проектов, это да. Ибо ненужное писать лениво.
>Это в интернете если только. Или за деньги? без понятия где. знал бы, сам использовал бы, а не тратил бы время на гугление. и он не должен тебя учить. Должен лишь быстро отвечать на вопросы, обсирать твой код и подсказать направление или немного показать пояснить.
В примере пикрил предлагается подписка на события таким образом: >new EventHandler<SomeEventArgs>(OnSomeEvent);
А как это используется, если ни на одно событие не подписаться дженерик- EventHandler-ом. Взять к примеру PropertyChanged в INPC. Выдается ошибка >Не удается неявно преобразовать тип "System.EventHandler<TEventArgs>"
Или я должен создавать свой делегат на основе EventHandler<TEventArgs>?
>>3261449 >Там в общих чертах, лучше на инглише? У Албахари есть два типа книг. Первый - краткий справочник по языку. Просто выжимка страниц на 300. Очень удобна например перед собесом за часик пролистать и освежить знания. Или вспомнить как работает фича которой не пользовался некоторое время. Второй - полный справочник на овер 1000 страниц. Там уже все подробно расписывается, с примерами и пояснениями. Книга актуальная и постоянно выходят новые версии, последняя по 12-му шарпу. Оригинал на английском, есть актуальные и неплохие переводы на русский. Читается на том и на том языке нормлаьно и легко.
>Опыт разработки? >Что мне говорить... когда я не работал уже 1.5 года. А что в первый раз по другой профе? Ну а что говорить. Тут стандартные два стула. Либо честно говоришь, что не работал, а учился/дрочил/болел, либо волчишь и рассказываешь про несуществующий опыт работы. Судя по твоим вопросам - второй вариант ты не потянешь, поэтому - упарывайся в обучение и старайся за это время создать какой-нибудь учебный прект и вылизать его до такой степерни, чтобы было не стыдно предъявить как хоть какой-нибудь опыт.
>занимаются php или 1с-битрикс Ну хреново, чо. Но даже у них хоть какой-то опыт есть и их можно поспрашивать про изнанку индустрии (безотносительно языка) >Или преподов по этому вопросу подергать? Дергать всех до кого дотянешься, прям доебывать.
>Значит игры... но это мне придётся ориентироваться на запад сразу? Я все-таки посоветовал бы тебе веб. Ты не геймдев разработчик. Это сразу видно.
>>3261711 но все же есть региональные предпочтения для языков это факт. суммарно по миру вроде много, а в твоем регионе ( локализации) может быть беда бедо
>>3261708 >Как по твоему источник события должен кидать само событие если у него типа нет. Он указан в моем классе. Да даже если указать явно, то получается пикрил
>>3261528 >мде, джуны никому не нужны Джуны нужны. Просто в нынешней парадигме, джун - это не тот, кто ничего не знает и только учится. А уже готовый специалист пусть и с небольшим опытом. Ты пока даже на стажера не тянешь, т.к. и на стажировку предпочитают брать людей людей с более-менее нормальным пониманием темы.
>>3261724 В абтрактном любом. В какой то стране могут преобладать одни вакансии, а в другой другие. А еще либо нужно знание языка (обычного которым глаголят) или не нужно.
>>3261726 ну я видел твой скрин. И значит мне не хватает инфы. (не в последнюю очередь что я просто пишу += и -= метод и не выделываюсь
и даже если создаю руками хендлер то потом его же инстанс и отписываю, а не создаю его еще раз (за что тебя и бьют по рукам)
есть такие строчки typedSource.SomeEvent += new EventHandler<SomeEventArgs>(OnSomeEvent); Я просто не пойму цель этой строчки. Используется дженерик хендлер, явно претендующий на универсальность, но не работающий со 100% всех событий. Я не понимаю что это и как это использовать.
>и вообще, бросай ты эту делегатную недохрень если для себя пишешь. Юзай lifetimes У меня есть проблема. Я хочу сделать конвертер значений, который при помощи рефлексии преобразует свойства объекта в условный словарь (кастомный, Freezable), чтобы на стороне XAML автоматически выводились данные объекта. Короче, хочу сделать что-то вроде окна свойств в вижуал студио. Потому что сейчас для каждой модели надо вручную собирать свою вьюху в XAML.
Но проблема в том, что в случае с привязкой к INPC модели, при изменении свойств со стороны модели, не идет обновления привязки и не срабатывает конвертер. И тут два варианта (по моему неопытному мнению): либо INPC заменить на Freezable, либо прямо из конвертера подписаться на PropertyChanged. Оба решения максимально дурацкие, и я думаю, как это решить иначе, но если подписаться из конвертера на PropertyChanged, то это создаст жесткую ссылку и не отпустит вьюху. Я пытаюсь сделать мягкое событие. Вот.
>>3261709 > >Там в общих чертах, лучше на инглише? > У Албахари есть два типа книг. > Первый - краткий справочник по языку. Просто выжимка страниц на 300. Очень удобна например перед собесом за часик пролистать и освежить знания. Или вспомнить как работает фича которой не пользовался некоторое время. > Второй - полный справочник на овер 1000 страниц. Там уже все подробно расписывается, с примерами и пояснениями. > Книга актуальная и постоянно выходят новые версии, последняя по 12-му шарпу. > Оригинал на английском, есть актуальные и неплохие переводы на русский. Читается на том и на том языке нормлаьно и легко. На рутрекере 10 нашёл только Поищу ещё По полочкам мне нравится > Судя по твоим вопросам - второй вариант ты не потянешь, поэтому - упарывайся в обучение и старайся за это время создать какой-нибудь учебный прект и вылизать его до такой степерни, чтобы было не стыдно предъявить как хоть какой-нибудь опыт. > Ну хреново, чо. Но даже у них хоть какой-то опыт есть и их можно поспрашивать про изнанку индустрии (безотносительно языка) Даж хз... не хочу там оставаться Да. Первое и сказал, когда пришёл на собес. А там битрикс. Потом подумал лучше подучить и в другой город. Т.к в моем городе кроме 1с ничего нет Тупой вопрос... а волки от слова walk? > Дергать всех до кого дотянешься, прям доебывать. Спрашивал, работы никакой не предлагают кроме этих же коллекторов или 1с(редко) > Я все-таки посоветовал бы тебе веб. Ты не геймдев разработчик. Это сразу видно. Ладно. А можешь объяснить как ты это понял? >>3261711 Также про Варкрафт говорят. Жду его перезапуск. Даж интересно что микромягкие сделают с ним после 2030
>>3261744 >typedSource.SomeEvent += new EventHandler<SomeEventArgs>(OnSomeEvent); это создается ЯВНО делегат указывающий на твой метод. портянку с new можно не писать ибо за тебя ее напишет компилятор (сахар такой)
И нет тут никакого дженерик хендлера. не путай open generic и closed generic Есть общий делегат EventHandler<T> и вот он должен иметь тот же тип что и событие, которое, в свою очередь такой же делегат.
>либо либо объявить подписку с пропертчиченджед.ехплисит и обновлять ее вручную когда посчитаешь нужным или Observable словарь. или взять готовые пропертигриды где народ уже сам с этим намучился
>>3261747 >Также про Варкрафт говорят. Жду его перезапуск. Даж интересно что микромягкие сделают с ним после 2030 Каким образом Microsoft относятся к Варкрафту, если это игра от Близард? Ну и если уж говорить о перезапусках старых стратегий, то как раз таки Майкрософт - это те кто ебут на этом поприще всех остальных. Я имею в виду серию Age of Empires Definitive Edition, и готовящуюся Age of Mythology Retold. Такого качества перезапусков RTS ни у кого пока не было. >>3261747 >А можешь объяснить как ты это понял? Я х.з. как это нормально словами объяснить, но для разработки в геймдеве нужно определнный склад ума иметь. По крайней мере ты не задавал бы вопросы "какую мне книжку почитать", а сидел бы сейчас и либо какой-нибудь движок ковырял, либо внутренности какой-нибудь игры, изучая язык просто экспериментируя в стиле "так сейчас вот тут поменяем и запустим. Ага значит вот эта штука позволяет запускать кусок кода несколько раз в цикле" и т.д. Тебе просто должно быть настолько в кайф ковыряться в кишках игор (а не играть в них), что это само по себе дает стимул изучать язык, как инструмент позволяющий это делать.
Если ты даже и сможешь выучиться и вкатиться в геймдев, то очень быстро поймешь, что это нифига не то, что ты себе представлял и там дичайшая потогонка, выгорание, низкие зарплаты и т.д. И нормально там живется только таким товарищам которых я выше описал.
>>3261756 >пропертигриды У меня WPF. Знаю, что есть и для него, но редко в таких штуках есть контроль.
>пропертчиченджед.ехплисит Можно подробнее? У меня была идея внутри вьюмоедли подписаться на PropertyChanged модели и оттуда вызывать PropertyChanged вьюмодели. Но это может привести к зацикленности.
>Observable словарь Он отображает только изменение итемов, а если у итемов меняются свойства, то словарь будет молчать. Нужен Freezable, но использовать его для моделей и вьюмоделей вроде как зашквар.
>>3261747 >Тупой вопрос... а волки от слова walk? Был какой-то то ли блог, то ли чат, где автор учил вкатунов как устроиться на работу любыми доступными способами. Называл коммьюнити волками, ну а способы заключались в пиздеже эйчарам и круговой поруке.
Кстати, до этих волчар, на дваче в 3d-разделе точно были треды от анона, который предлагал объединиться и зарегать фейковую контору, поделать совместные проектики для артстанции и насрать опыт себе в трудовые книжки. Идея тогда не воплотилась — подумали, что ОП-хуй пытается эксплуатировать анонов. Но дело его живет и заразило собой IT сектор.
>>3261790 у биндингов есть UpdateSourceTrigger=Explicit который позволяет вам вызывать обновление источника когда вам угодно. Иногда даже приходится использовать. вот как то делал DoubleTextBox. чтобы туда можно было ввести только числа и разделитель и замахался бороться с разделителем который летел на source и все там ломал. Не помню точно, вроде.... если у тебя число в текстбокс 49.9 и ты удаляешь и получается 49. то конвертер конечно превратит это в 49 дабл, но тут же обратно прилетит 49.0 и засрет тебе тексбокс.
>>3261821 >Не помню точно, вроде.... если у тебя число в текстбокс 49.9 и ты удаляешь и получается 49. то конвертер конечно превратит это в 49 дабл Да, у меня было такое.
>UpdateSourceTrigger=Explicit Я вроде этот Explicit юзал, но для того, чтобы обновлять привязку текстбокса по нажатию Enter. Щас попробую.
>>3261821 Если я правильно понял, ты из тексбокса принудительно вызываешь обновление. Но ты же обновляешь только одно свойство, к которому текстбокс привязан, просто ты его обновляешь в нужной тебе ситуации. Но это не то, что мне нужно. У меня события свойств и так происходят.
Вот смотри, у меня во вьюмодели (на скрине не видно, это MyViewModel) есть свойство TestINPCClass (пикрил 1), как выглядит этот класс, изображено на пикрил 2 — там три тестовых свойства.
Если я привяжусь к свойству TestINPCClass.Color, и поменяю значение, то я вызову событие TestINPCClass.PropertyChanged. Но я не вызову событие MyViewModel.PropertyChanged, а именно последнее заставит обновиться мой конвертер. Мне Explicit никак не поможет.
>>3261882 А вот если бы свойство TestINPCClass содержало Freezable-объект, то изменение значенияTestINPCClass.Color, вызвало действия аналогичные MyViewModel.PropertyChanged
>>3259470 Если ты ещё не понял, я нюфаг в С#. У вас тут какие-то полные, краткие синтаксисы, поддержки редакторов, черти лысые. Без пол литра не разберёшься.
>>3259700 >Зачем мне специальные конструкции конкретного ЯП которые как раз были созданы под моего рода нужды если можно ебаться с массивами?" Придумал про меня хрень какую-то и остался доволен. Я нигде не говорил что отказываюсь от ref/out. >что ты делал по учебе и близко не стоит к тому как на самом деле пишут код сейчас на Си/Си++ Откуда ты знаешь о моих знаниях о том как пишут код Си/Си++? >жаль Почему жаль? Жалеешь что вышку получил?
>>3259959 >Вот ты даже не понимаешь значения документации. Каким боком "для себя" оправдывает её игнорирование? Фразы "для себя" и "у нас не экзамен" используют только опущи с тремя классами образования. Для себя делают хорошо, но у долбоебов принято для себя делать спустя рукава. М-да? А моё потраченное время ты оплатишь? Ты на каждый свой пук документацию пишешь? >Если в шараге такому учат, то там явно отсутствует контроль качества. В шараге я как раз Си/Си++ учил а не #.
>>3259939 >Ты тот чел, который собирался делать одноэлементные массивы? Вышка чего у тебя? Клоуна? Я делал одноэлементные массивы в отсутствии информации о ref/out и прочем. И как видишь сумел выкрутится и решить возникшую проблему. А всё почему? Потому что я - Си-господин с вышкой, а вы #-холопы после говнокурсов.
А вообще вы тут какие-то гиперчувствительные. Теперь понятно почему в ваш тред любят жабисты захаживать. Привет >>3259939 -клоуну!
>>3261882 ты идешь не туда. никто не запрещает событиям работать во все стороны (главное отписку продумай)
Если у тебя псевдокод rootVm.PropertySet { a: String, b: int} и ты биндишь a и b, но хочешь чтобы при их изменении еще и rootVm знала об этом - ну так сообщи ей об этом прямо. Можешь выставить событие у PropertySet, на которое подпишется рутовая вьюмодель. Или она может подписаться на тот же INPC и реагировать как хочется.
для этого события и придумали. лишь бы с отпиской все было хорошо - у тебя это и weak event и "циклическая подписка не ведет к утечкам памяти", у меня lifetime, которые я рекомендую всем налево и направо.
>>3261775 > >Также про Варкрафт говорят. Жду его перезапуск. Даж интересно что микромягкие сделают с ним после 2030 > Каким образом Microsoft относятся к Варкрафту, если это игра от Близард? Я про ммо. Стратежку вряд-ли кто то перезапустит > Я х.з. как это нормально словами объяснить, но для разработки в геймдеве нужно определнный склад ума иметь. По крайней мере ты не задавал бы вопросы "какую мне книжку почитать", а сидел бы сейчас и либо какой-нибудь движок ковырял, либо внутренности какой-нибудь игры, изучая язык просто экспериментируя в стиле "так сейчас вот тут поменяем и запустим. Ага значит вот эта штука позволяет запускать кусок кода несколько раз в цикле" и т.д. Тебе просто должно быть настолько в кайф ковыряться в кишках игор (а не играть в них), что это само по себе дает стимул изучать язык, как инструмент позволяющий это делать. Наверное я просто в них так не ковырялся никогда. Не возникало причин. Разве что приходилось по куче раз моды переставлять в том же морре. Да и какие то челы уже перетаскивают её на другой движок > Если ты даже и сможешь выучиться и вкатиться в геймдев, то очень быстро поймешь, что это нифига не то, что ты себе представлял и там дичайшая потогонка, выгорание, низкие зарплаты и т.д. И нормально там живется только таким товарищам которых я выше описал. Но ради чего эта вся романтизация? >>3261776 Я патологически не могу врать, т.к чувствую себя неловко Мне наверн будет тяжело... как и по всей жизни было. Считали бестактным некоторые >>3261799 Интересно. А ведь это понятие везде используется
Сука, я не могу. Как же меня доебало это ебучее `is already being tracked`. Почему блять нельзя просто взять и не дать тречить другому? И офнуть полностью этот трек нельзя, ибо оно вообще перестанет лазить в бд. Хули оно через жопу-то так работает..
Приходится делать какие-то маразматические проверки, что я не верблюд и не беру дважды одну и ту же ентити. Я уж молчу об ахуенном трай кэтче и роллбэке явном.
>>3262198 Я честно сказать вообще не понимаю как этот механизм работает. Типа в некоторых случаях, бд просто перстает обновлятся, даже селект не идет. Руки вероятно кривые, но все же.
Да и я например не хочу отключать все эти отслеживания, а просто детачнуть один объект и аттачнуть его уже в другом месте. Не выкупаю, почему это не работает. Типа ну нахуя-то же эту хуеверть сделали, возможно есть более разумное примение и обоснование ее существования.
Есть вопрос по правильной™ асп.нет архитектуре. Делаю веб приложение, в проекте есть уровень репозитория который взаимодействует с бд; уровень сервиса который взаимодействует с репозиторием и преобразует данные для отображения клиенту; и непосредственно контроллер который их возвращает со своей дополнительной логикой. В чем суть - раньше я логику выносил в отдельный класс которые логически делил (класс-инициализатор, класс который отслеживает куда пользователя нужно редиректнуть и загрузить ему нужные данные и т.д.) и жил я без этих выше описанных слоев (просто с MVC архитектурой). Сейчас при попытке вынести основную логику в отдельный "utility" класс я передаю в методы просто интерфейс сервиса (да, я заранее понимал что это уже какое-то ебланство) если быстро делать на клиенте какие-то действия - кидает EF исключение database context is already used. Варианты как это пофиксить которые я сейчас вижу: - Вынести всю логику в контроллер. Подводные - очень большой контроллер в котором будет как минимум овер 4к строк, когда реально там нужно не более 500. - Сделать для логики отдельный сервис. Подводные - копипаст кода, т.к. я не могу из сервиса вызвать другие сервисы. - Попробовать заинжектить сервис менеджер в текущий "utility" класс в котором не передавать интерфейсы сервисов через аргументы, а обращаться к уже внутреннему свойству класса. Подводные - я пока хз можно ли так делать + не уверен пофиксит ли это обращение к dbContext'у из нескольких мест.
Как вообще правильно такое делается в этих ваших тырпрайзах?
>> в проекте есть уровень репозитория который взаимодействует Подумай вот о чем - EF это уже и есть репозиторий. Если хочешь йоба сервис для всего пили CRUD дженерик репозиторий, но тогда и юзай его везде как надо, но потом ты поймешь что EF делает тоже самое.
>> логику в отдельный "utility" класс Ты че ебнутый? Utility классы нужны для всякой хуиты типа перевода даты из одного формата в другой, потому что долбоебы спроектировали фронт или для перевода ру текста в транслит и т.д.
>> Вынести всю логику в контроллер. Гугли "толстые тупые контроллеры", так делают "необучаемые макаки с 50 лет стажу потому что у них так дед дела и они так будут делать".
>> - Сделать для логики отдельный сервис. Самая адекватная идея.
>> Как вообще правильно такое делается в этих ваших тырпрайзах? Описал сучность Создал к ней сервис Создал контроллер Заинъектил этот сервис в контроллер
>>3262520 > Подумай вот о чем - EF это уже и есть репозиторий. Если хочешь йоба сервис для всего пили CRUD дженерик репозиторий, но тогда и юзай его везде как надо, но потом ты поймешь что EF делает тоже самое. Нет, ef это ef. Он не решает задачу абстрагирования от уровня хранения данных. С ним ты никак не мокнеш данные для тестов например.
>>3262207 Немного разобрался. Обычно такое возникает, если какой-то контекст тянет из бд кортеж, который есть в другом контексте. Конечно вообще не удобно, что есть несколько разных контекстов, с разными бакетами. Но по крайней мере понятен источник проблемы и как ее решить. Впрочем в идеале бы вообще убрать деталь реализации в виде ебаного детача.
>>3262550 >> Как мне правильно дергать другие сервисы в этом сервисе? Инжектнуть их?
Возможно проще будет собрать отдельный сервис куда заинъектить все нужные сервисы, это конечно может вызвать доп телодвижения в виде сущностей\репо, но это лучше чем нарваться на circular dependency в самый неожиданный момент и ебаться его разруливать, а это в готовой приложухе бывает не просто и как правило заканчивается дерганием в методе нужного сервиса через инстанс контейнера.
>>3262774 >> А берут ли куда с растом в рф? Сейчас не берут, просто когда начнут брать у тебя будет 0 опыта и ты никому нахуй не нужен будешь, как не будешь нужен со знанием крестов. Вот такие вот ножницы, выбирать тебе
>>3218902 (OP) Подскажите нубу, нужно написать небольшое кросс платформенное desktop приложение (windows + linux), основная суть в выводе графиков и диаграмм. Это можно сделать на c#, используя AvaloniaUI? Не хочется qt и плюсы трогать.
Аноны вопрос по WEB разработке на .NET какой фреймворк сейчас актуален?
я вот скачал Rider там мне на выбор: Blazor, Web API, Web App, razor какой-то, gPRC а я вообще начал ASP.NET учить, но там уроки 2-3 годичной давности. Может Web App(MVC) это и есть ASP.NET? поясните неофиту за web пожалуйста
>>3263154 > какой фреймворк сейчас актуален? ASP.NET. > а я вообще начал ASP.NET учить, но там уроки 2-3 годичной давности. Судишь об актуальности фреймворка по наличию васянских туториалов на русском? > Может Web App(MVC) это и есть ASP.NET? Нет.
сам я линуксоид, байтёб пишу/писал на плюсах делаю перекат смотрю различные другие языки. ебать я в шоке от хаоса который твориться в индустрии, ну да ладно. Пришел для себя к выводу что С# наиболее оптимальный вариант, т.к. кросплатформенность, развитый и разнообразный стек технологий, и можно ради это закрыть глаза на ебучий микрософт какие еще варианты есть: - вечная джава, хз чисто ментально туда не хочу, не знаю почему даже - rust перспективен, но пока рановато - Go что скажете за Go?, гугл же все таки
надеюсь я сделал правильный выбор, хотя в целом мне похуй
>>3263108 Да, с авалонией легко такой сделать, мельтитаргет с одним проектом под общую логику, и отдельные проекты под конкретные платформы будут. И какой-нибудь scottplot для графиков взять.
>>3263220 >- Go что скажете за Go?, гугл же все таки удивляет уродливый синтаксис этого говна. Про раст говорят что там инопланетный синтаксис, но на деле все наоборот. Такое ощущение что го исповедует принцип "а давайте сделаем чтобы не как у других, чтобы отличаться"
>>3263154 >я вот скачал Rider там мне на выбор: >Blazor, Web API, Web App, razor какой-то, gPRC Это не фреймворки, а шаблоны проектов. И, сюрприз, там под капотом везде будет ASP.NET даже у блазора.
>>3263220 >можно ради это закрыть глаза на ебучий микрософт >что скажете за Go?, гугл же все таки Я не понимаю каким образом в голове у людей складывается идея "майкрософт - плохо, гугл - хорошо". И то и то - злоебучие корпорации стремящиеся только к увеличению прибыли.
Не могу понять слабые ссылки. Сделал WeakReference к методу из окна. Закрываю окно, и WeakReference.IsAlive может показать false спустя секунду, а может спустя пять минут. А может вообще никогда не показать. Вот и думай.
Или взять WeakEventManager. Я создал окно, и при изменении DataContext подписываюсь на PropertyChanged модели (пикрил). Метод TestModel_PropertyChanged срет в окно интерпретации каждый раз, когда я меняю значения свойств модели TestModel. Далее я закрываю окно, после чего вероятность отписки (о которой я сужу по сообщениям в дебаг) выглядит как чистый рандом.
Я могу это как-то связать с настроением GC, но я ради теста прождал минут 20 и порой изменений нет. Я создаю новое окно и тут же закрываю. Отписка от нового произошла мгновенно, а предыдущая осталась висеть. Вот по какому принципу это работает?
>>3263527 >Вот и думай. чего там думать. Как GC проснется - так и почистит. Когда проснется? Когда захочет, да и то твоя ссылка может лежать во втором поколении, а до его чистки дело не дойдет. Памяти хватает, системе не нужно, GC не дергается.
>выглядит как чистый рандом. те же самые правила. Окно умрет сразу конечно, но вьюмодель то про это не знаешь (если ей сам не скажешь) и продолжает принимать сообщения которые уже не нужны. Ну пока GC не проснется и не прихлопнет её тем самым вызвав отписку.
>могу это как-то связать с настроением GС с ним и только с ним.
>Отписка от нового произошла мгновенно 0 поколение же. Чистится наиболее часто.
>>3263527 >Памяти хватает А это сколько? Не хочу, чтобы мое приложение жрало гигабайт только потому, что памяти в ОЗУ хватает.
>Окно умрет сразу конечно, но вьюмодель то про это не знаешь (если ей сам не скажешь) и продолжает принимать сообщения которые уже не нужны. Там два варианта. Один это через своего рода WeakEvent, внутри которого находятся мягкие ссылки. А второй через WeakEventManager, но этот хранит обычные подписки, и его не особо рекомендуют.
"Сборка мусора возникает при выполнении одного из следующих условий: ... Объем памяти, используемой объектами, выделенными в управляемой куче, превышает допустимый порог. Этот порог непрерывно корректируется во время выполнения процесса. ... "
А поскольку Dispose паттерн дырявый как (цензура), то поэтому и используют слабые события. Хотя правильнее использовать lifetime-ы, но на момент изобретения WPF не додумались.
>>3263686 Нет, не просто. Я хочу WeakEvent или WeakEventManager использовать для своего конвертера значений (который я упоминал выше), а он не знает когда будет выгрузка контрола-родителя, в ресурсах которого он хранится. Либо в этот конвертер пихать ссылку на родителя, чтобы подписаться на Unloaded.
Я думаю, какой вариант выбрать, но чем проще, тем менее надежно. Либо заставлять модель создавать WeakEvent, либо заставлять представление передавать ссылку на себя. Либо обновлять свойство вьюмодели при каждом изменении свойства модели и тогда напрягать вообще всех, кто к этому свойству подписался. Либо для модели вместо INPC использовать Freezable. Либо городить лайфтаймы.
Но вот такого решения, чтобы без мороки подключить конвертер, который бы автоматически отслеживал изменения свойств модели (кроме мягких ссылок), пока не нашел.
>>3263742 >Капец ты жадный на инстансы Инстанс чего? Контрола? Этот контрол может хранить в себе тяжелые данные, типа битмапов, и может быть элементом какого нибудь списка. У меня так приложение начинало жрать 300Мб.
>А вообще конвертер выгрузится вместе с контролом. Если конвертер подписался на модель по принципу >value.PropertyChanged += OnPropertyChanged; то контрол не выгрузится, потому что в событии модели лежит ссылка на метод OnPropertyChanged.
>то контрол не выгрузится, потому что в событии модели лежит ссылка на метод OnPropertyChanged. поэтом слабые события для INPC и придуманы. Ну да, будет вызывать еще некоторое время (вернее может вызывать) и что? гуи все равно уже ничего делать не будет, ведь контрол выгружен.
>>3263785 будет пока GC не скушает конвертер. но сам контрол не будет заниматься задачей рисования изменений.
К тому же никто не запрещает отследить в контроле выгрузку (unloaded / window.close ) и сказать конвертеру "прекрати обрабатывать события то есть отпишись от модели"
>>3259486 >>3259618 Конкретную аргументацию попрошу. Пока от вас только одни вскукареки >ко-ко-ко это другой язык кудах-кудах у нас так принято кукарек гладиолус
>>3263901 Ты читать то хоть умеешь или совсем хлебушек? Тебе прямо ссылку кинули где разъясняется как контекст видимости в шарпе работает. То, что это не соответствует твоим ожиданиям - исключительно твои трудности.
>>3263901 >Конкретную аргументацию попрошу. Потому что в твоей глупой конструкции нет практического смысла, но которая мешает другому сахарку, более полезному. Вот и вся аргументация.
Потому что вот так устроена жизнь. Ты либо строго придерживаешься правил и страдаешь как в C++, либо упарываешься развратом и содомией как в джава скрипте, либо пытаешься придерживаться правил, но иногда кладешь на них блот, чтобы жизнь была чуть слаще — это путь шарпа.
Помимо предоставленной выше статьи про "блоки кода", хотел бы упомянуть лямбда выражения, которые позволяют объявлять внутри себя локальные переменные: > int i = 3; > var useless = () => > { > int i = 5; //локальная переменная с тем же именем > };
Но ничего не мешает сделать и так: > int i = 3; > var useless = () => > { > i = 5; //присвоение значения переменной, объявленной до блока > }; т.е. если переменная не объявлена внутри блока лямбда выражения, то ее поиск начнется за его пределами (но не дальше области видимости функции). Почему так сделали? Ну если отбросить понятия и каргокульт, а вернуться к здравому смыслу, то для чего нам понадобятся подобные блоки внутри функции? Для многократного выполнения большого объема кода, и тогда становится понятно, что бессмысленная строгая инкапсуляция тут не нужна.
Кстати, работает так же как методы и с полями:
> int myValue = 5;
> int GetMyValue_A() > { > int myValue = 10; > return myValue; > }
> int GetMyValue_B() > { > return myValue; > }
> Console.WriteLine(GetMyValue_A()); // вернет значение локальной переменной: 10 > Console.WriteLine(GetMyValue_B()); // вернет значение поля: 5
>>3263984 >Кстати, работает так же как методы и с полями: Ну так в спеках так и написано, что объявление переменных в области видимости кода перекрывает те, что были заданы в области видимости класса, но не те, что были заданы в области видимости метода. Поэтому поля и перекрываются.
И тащемта это нифига не инкапсуляция, а полиморфизм, если уж в термины ООП влезать.
>>3264009 >Ну так в спеках так и написано, что объявление переменных в области видимости кода перекрывает те, что были заданы в области видимости класса
Тогда это бы работало: > int i = 3; > { > int i = 5; > }
>>3264130 ты сравниваешь теплое с мягким. WPF вообще не паттерн. это фреймворк для построения GUI.И вот он уже дружит с паттерном MVVM, который уже паттерн типа MVC только другой
>>3264137 спасибо за ответ стало понятней тогда если не сложно, можешь ответить ещё на один вопрос
вот я использую например в своем приложении пространство имен: System ну или там SystemData я их подключаю в коде используя using сами эти библиотеки я нашел в папке ... nuget это CIL файлы как я понимаю. В какой момент они конектятся к программе? Они вроде как находятся в CLR пространстве. Т.е. в начале мой код на С# транслируется в CIL. Затем уже CLR также линкует эти библиотеки к моему коду и затем все вместе в машинный код?
>>3264157 ну у тебя и вопросы. 99% это нафиг не нужно. твои using и использование классов оттуда являются просто текстов в текстовом файле *.cs
А далее используя подключенную длл (неважно откуда) IDE может использовать метаинформацию о классах и прочем из этой сборки чтобы подсказывать тебе "тута плохо".
А потом уже компилятор будет использовать ту же инфу и запишет что для твоей сборки нужны вот те зависимые сборки и мол после их загузки появится то, что можно вызвать будет вот так. там оно все как то свяжется в рантайме и будет хорошо
из этого следует что даже в статически типизированном языке можно подгрузить в рантайме не ту сборку и получить "метод не найден".
>>3264229 А я чет пытаюсь наследовать просто WeakEventManager<TEventSource, TEventArgs>, а мне пишет "не содержит конструктор, который принимает аргументы 0". Но других конструкторов и нет, да и все методы статические. Наверно это автор пытается обойти.
Все работает, я проверил с помощью событий в конфигурации, оба работают и жрут каждый свой токен.
Бида какая. Разрабы не особо замарачивались и просто если один упал вызывают другие если есть и все, но у нас в проекте есть класс middleware своей который ловит контекст запроса и достаёт данные авторизации передавая HttpContext в наш собственный контейнер. Так вот эта мидлваря ловит только ПЕРВУЮ попытку, если она провалена и мы использовали второй вариант, то она не вызывается и в итоге обосрамс. Тут вот написано https://learn.microsoft.com/en-us/aspnet/core/fundamentals/middleware/?view=aspnetcore-8.0 Что все пользовательские мидлвари вызываются после всех .НЕТ приседаний, но почему тогда моя мидлваря вызывается сразу после первой аутентификации, а не после всех?
Какие есть варианты получения контекста до момента когда будет исполнен любой код и после всех штук в самом .НЕТ? Либо в чем я не прав?
>>3264499 Все нашёл решение проблемы. Удалили из проекта все что было понаписано до меня для мидлварей и прочей архетуктуры и в фабрике контекстов использовал IHttpContextAccessor. Через него контексты получаются нормально.
Минус 5 классов и 300 строк кода. Плюс 4 строчки кода для получения контекста через аксессор.
>>3264537 Блять долбач ты обосаный. Там имеются ввиду кастомные мидлвари. Все твои написаные тобой будут вызваны в том порядке в каком указаны ПОСЛЕ стадартных мидлварей. Также сами родные мидлвари должны идти в определённом порядке чтобы нормально работать.
Ещё раз для тупых ебанатов как ты. Всё твои мидлвари вызываются только после работы всех внутренних кишок. Никто тебе не даст выполнить твою хуйню посреди процесса авторизации.
Тебе английским языком пишут что существующие ты можешь как угодно менять порядок И добавлять по необходимости свои. Там ничего не сказано что они будут вызваны там где ты их сунул. Оно так не работает.
>>3264229 >кстати, каноничный паттерн это - у него (наследник как дженерик параметр базового класса) даже свое отдельное название есть, которое не помню. Лол. Тоже постоянно пользуюсь таким и в дуже не ебу как этот паттерн называется.
Ну так иди и Хейлсбергу этот вопрос задай. Он еще жив и вполне может тебе ответить. А нам плевать. Мы знаем как это работает и не ебем себе мозг вопросами "а почему в С++ или Java по другому"
Тебе прямо сказали, что лезть в другой язык (даже родственный) со своими представлениями о том как должно быть - хреновый подход. Нет нигде никакого глобально правила, о том как и что должно реализовываться в языках. Каждый делает как хочет. Максимум что, можно под глобальные правила подтянуть - это полноту по Тьюрингу.
>>3264608 >Ещё раз для тупых ебанатов как ты. Всё твои мидлвари вызываются только после работы всех внутренних кишок. Никто тебе не даст выполнить твою хуйню посреди процесса авторизации.
Вопрос по зануляемым ссылочным типам, есть примерно такой код, но компилятор пишет ворнинг на последней строке якобы она может быть null. НО разве проверка obj as ISomeне не исключает этотого?
object? obj;
var someObj = obj as ISome; if (serializableObj == null) { obj = 1; }
>>3264830 У тебя ToString находится за пределами блока if. Компилятор не настолько умен, как ты думаешь. Система проверки видит, что присваивается какое-то значение, а какое — хз (может оно тоже null), поэтому выдает предупреждение.
Единственное, что понимает компилятор, это если бы в твоем блоке if стоял return. Ну или пиши со знаком "!" > obj!.ToString(); если абсолютно уверен, что null не придет.
>>3264823 >НО разве проверка obj as ISome не не исключает этого? У тебя какой-то бардак, даже если допустить, что это просто пример. Почему ты кастуешь к ISome, но присваиваешь 1? Это вообще разные типы, от чего и появляются проблемы. Кроме того, ToString() допускает возврат null, тогда зачем эти танцы с присвоением единицы? Но в реальности никто так не делает, соответственно и такой проблемы нет:
> string? result = obj is ISome someObj ? someObj.ToString() : string.Empty; или так > ISome some = obj is ISome someObj ? someObj : new Some(); > some.ToString();
Как только ты срешь в переменную разными типами, вот тогда и начинаются траблы. Ты вот даже вроде бы проверил obj, а снова срешь единичкой чтобы что? Чтобы снова проверять на валидное содержимое?
>>3264823 Я даже не знаю какой пример лучше написать, помтоу что я не понимаю, для чего ты кастуешь к ISome, вместо того, чтобы использовать object?.ToString().
МОЖЕТ БЫТЬ ты в блоке if хочешь реализовать кастомный конвертер, но тогда выглядит деструктивно, потому что ты меняешь obj, вместо того, чтобы формировать string (а лучше StringBuilder). Но даже в оверрайднутом ToString() не может быть проверки на null.
Пример настолько нелогичный, что даже не знаешь куда копать.
>>3264919 > string? result = obj is ISome someObj ? someObj.ToString() : string.Empty; точнее даже так > string? result = obj is ISome someObj ? someObj.ToString() : null;
>>3264896 Если obj null, то someObj тоже null, а значит ему будет присвоено не нулевое значение в блоке if.
>>3264903 Понятно. Предполагал такое но не знал наверняка. Просто тогда какой смысл во всей этой хуерге с (не)зануляемыми ссылочными типами если ворнинги опять вручную давить, да еще под это дело корежить код.
>У тебя какой-то бардак Может у вас, я кажется пару раз дал понять что это максимально краткий пример для выяснения языковой фичи, что за ним стоит не важно? Естественно там не 1 и не ToString, раз уж спалился речь идет о сильно кастомном сериализаторе которые может обрабатывать любой тип: простой, структуры\классы или специальный с интерфейсом у которого особая логика работы. Соответственно во внутрених методах при проходе по дереву свойствнужно разруливать было лы вообще начальное значение у свойства, было оно простого типа, структурой или интерфейсом и каждое из этих ветвлений требует своих действий.
>>3264964 >Просто тогда какой смысл во всей этой хуерге с (не)зануляемыми ссылочными типами если ворнинги опять вручную давить
Оно должно напоминать, чтобы ты случайно не забыл это сделать. Ну и как я уже писал, если ворнинги приходится подавлять, то возможно код сомнительный. Не сказать что всегда, но в большинстве случаев.
Единственное исключение, это ворнинги при инициализации, когда в конструкторе пытаешься задать дефолтное значение поля через свойство. И там нельзя просто поставить "!".
>Может у вас, я кажется пару раз дал понять что это максимально краткий пример для выяснения языковой фичи Так в том-то и суть, что когда делаешь норм, то и она работает норм. А смысл обсуждать поведение фичи, когда код не норм?
>>3265039 варнинги много где приходится подавлять. Анализатор в шарпе весьма тупенький. Банально нет lateinit, многочисленные аттрибуты для контроля хрен пойми как вообще работают (смотришь сигнатуру словаря TryGetValue, копируешь для своих трагетов - не работает. Меняешь аттрибудт на противоположный - работает, ааааа)
<code> delegate unmanaged[Cdecl]<WGPURequestAdapterStatus, WGPUAdapterImpl, sbyte, void, void> callback </code> Шарпаны а как такой метод вообще создать.... и передать.
>>3220125 самое простое - не привязываться в данном случае к определенному GUI, пусть бэк предоставляет апи, а фронт в любом реактивном фреимворке на выбор, тот же хром запустишь на почти любой ОС.
>>3265773 Потому что проекты не связаны. В обозревателе решений твоего проекта есть нода "Зависимости". Кликай по ней ПКМ и выбирай "Добавить проект". По умолчанию тебе покажет список проектов твоего решения, но ты так же можешь при помощи кнопки "Обзор" внизу, выбрать проект из стороннего решения.
Единственное правило: зависимости односторонние и не должны замыкаться. Т.е. ты не можешь добавить зависимость с Program.cs на test.cs, потом добавить обратную зависимость с test.cs на Program.cs. Если ты захочешь, грубо говоря, двухсторонний обмен данными между проектами, то сосни хуйца — для этого нужно городить города.
Так же dll-библиотеки добавляются (но лучше юзать nuget).
>>3265852 Ах да, в первый раз тебе захочется выделить проект в списке и нажать ОК, но ничего не произойдет. Слева от названия проекта в списке есть чекбоксы — вот их надо активировать над теми проектами, которые ты хочешь залинковать, и уже потом нажимать ОК.
Если все сделано правильно, то в ноде "Зависимости" появится нода "Проекты" в которой будет список залинкованных проектов (пикрил 2).
>>3265863 да антоша дело в этом. Я только сейчас понял С# - это чистый ООП язык, в отличие например от С++ (откуда я пришел), который только поддерживает парадигму ООП. И получается все top-level statements это все находиться внутри функуции main и класса программ. Бля прихуел я конечно с этого немного. всем спасибо за помощь
>>3265739 Нихуя. Наллабл референс тайпы исчезают при компиляции оставляя только атрибуты и не меняя поведение кода. Наллабл структуры же просто обёртка в виде Nullable<t>
Я что-то вообще перестал понимать как работают потоки что ли. У меня есть 2 метода. Оба запускаются на главном потоке. Первый отрабатывает раньше, второй позже. Первый создаёт файл и пишет в него. Второй пытается писать и не может нихуя, как я понял, потому что файл каким-то образом залочен первым. К моменту работы второго метода, первый уже 100% отработал. Если второй запустить на отдельном потоке, то всё прекрасно пишется. Почему так? Файл-то один и тот же. Ноль понимания того, почему это происходит, просто ноль.
>>3265945 В моей голове я всегда думал, что если методы запускаются на одном потоке, то у них есть доступ ко всему, что на нём создано, будь то файлы или ещё что. А тут оказывается, что один метод может залочить файл для другого метода на том же потоке. Я правильно пынямаю или нет? Буквально впервые с такой хуйнёй сталкиваюсь за 5 лет
Был класс, с какой-то логикой. Допустим, компьютер. Довольно абстрактный, но достаточный. Все в нем реализовали. Было заебись. Вот. Но появилась такая вот хуйня, что нужно по разным причинам иметь теперь телебон(с рассчетом что это смартфон), и ноутбук. Оба - должны повторять интерфейс компьютера, но при этом - иметь ряд плюшек. Вроде - ниче сложного же. Но вот у телебона появляется такая хуйня, что он может быть и не компьютером, а просто дисковым. Вот так вот случилось, хуль поделать, из функций только звонить должен уметь. Вот.
В общем-то теперь проблема про что. Если я сделаю с помощью стратегии, и телебон - будет иметь интерфейс компрьютера - мне теперь придется, в интерфейсе звонилки - все равно методы компьютера определить. А мне это не уперлось. А иначе - придется в классе телебона - делать постоянные ветки, дескать - ну, я ж звонилка - извините, о, не звонилка - теперь я это могу.
Не знаю, понятно чи нет. Но вот с такой проблемой столкнулся, и хрен знает как красиво это разрешить.
>>3266312 Либо COP, либо покрывать то-что должно отключаться флагами и при создании объекта подсовывать ему нужный конфиг (что по сути тоже COP, только сбоку)
В общем по этому поводу >>3266312. Писал заебанным и криво описал что хочу.
Мне хочется вот поведения, чтобы с одной стороны - типа наследование(в том плане, что я написал какой-то кусок кода, и он теперь у наследника, без всяких там прокидываний инстанса и передачи вызова уже туда), с другой - интерфейсы, с третий - отсутствие ебатории с тем, что я строю эти ебаные композиции, и пробрасываю куски к тому что реально что-то реализует.
Идеальным для меня было бы что-то типа миксинов+утиной типизации.
В жсах-тсах, это достигается легко. А вот как сделать что-то подобное в шарпах, не извращаясь с рантайм генерацией типов - я не знаю.
>>3264684 в 3 потока выходит 2,5-3кк пакетов в сек (пустые icmp 8) + парсинг каждого. Выглядит что уже упор куда то в ядро лини т.к. банальные увеличение потоков до 4х роняет суммарную производительность к 350-400к пакетов. Утилизация канала за гигабит, если в пакеты пэйлоад добавить то думаю 3-4 гбита точно будет Пробовал оффлоадинг - без результатов. Все тесты гонял на дебаг билде т.к. в производительность рантайма похоже упора не было
Немного не шарповый вопрос для анонов с большим опытом: насколько плохо работать в продуктовых командах по сравнению с инфраструктурными? Верно ли предположение, что если разрабатываешь какие-нибудь инфровые штуки вроде деплоя/очереди сообщений/хранилища данных и всё такое, то опыт переносим на другие компании, в отличие от работы в продуктовых командах?
Почему мне так кажется: Два года уже работаю в одной и той же команде мимовыпускник, пришел стажером и стал вроде как мидлом, процессы на галере хорошие, зарплата норм, но есть несколько нюансов, которые меня заебали: 1. Я не понимаю до конца предметную область (окологосхуйня), не пользуюсь конечным продуктом, да и предметная область скучна сама по себе. Работать над задачами из-за этого часто тоже скучно. 2. Те области предметки, которые знакомы, страшны - это многослойная бизнес-логика, иногда с отсутствием внятной документации ну а хуле, найди тикет четырехлетней давности, вот тебе и документация. Усугубляется это тем, что часть моей работы это разработка инструментов для последних линий техподдержки, там абсолютно ебанутейшая логика бывает иногда. 3. Сеньорность в команде определяется не техническими знаниями, а пониманием всратой бизнес-логики. И качество кода у некоторых сеньоров не очень, они просто быстро клепают говно под требования бизнеса. Есть ощущение, что почти ни у кого ничему новому в этом месте научиться уже не смогу, поэтому клепаю пет-проекты, но времени на них мало. 4. Большая часть получаемых знаний будут неприменимы на другой работе - будет снова другая предметка, снова такой же говнокод, единственное, может повезти с тем, что продукт будет нравиться.
Может, в инфраструктурных командах тоже есть всё вышеперечисленное и я их идеализирую, аноны? Или есть какие-то другие обратные стороны медали работы в них, которые не учитываю? Или зря выебываюсь и лучше сидеть в нынешнем теплом месте и пилить свои пет-проекты?
>>3268163 Ну хер его знает, чел. Тут сначала бы определиться, что ты считаешь продуктовым проектом, а что инфраструктурным.
Я вот вроде бы на инфраструктурном проекте (по крайней мере он таковым вроде считается) в финтехе работаю, так вот там было все то же самое, что ты отписал. Один в один практически. Нас по сути из болота вытащило импортозамещение, т.к. позволило присесть на уши руководству, что для него непременно нужен переход на самый свежий стек из доступных, плюс добавить всякого, чего не было, вроде кубера, кафки и т.д. В итоге и сами развились и смогли перетрясти требования и формализовать все, что нужно.
Из плюсов (по крайней мере у нас) то, что релизы очень редкие и нет безумной гонки от спринта до спринта. Из минусов - больше ответственность, т.к. ошибки могут к миллионным убытками приводить. Это несколько напрягает.
Под инфраструктурным проектом понимаю полное отсутствие бизнес-логики, связанной с конкретным продуктом. Например, всякие инструменты разработки и деплоя, телеметрия, собственные хранилки какие-нибудь.
Из примеров продуктовых проектов: всякий фронт + бэк с какими-то фичами, работа над которыми не доставляет. Ну или круды на бэке, в которых какие-то ребусы из предметной области решаете и тягаете свои несколько тыщ рпс на микросервис.
Последнее время думаю, что это стремная работа, плюс, любой школьник может сделать что-то на реакте и шарпе и заменить тебя в теории. А чела, который пишет условные инструменты телеметрии, школьник заменить не может, в интернете нет готовых гайдов как это сделать
>>3268497 Понятно, у меня несколько другое представление об этом разделении.
>>3268497 >любой школьник может сделать что-то на реакте и шарпе и заменить тебя в теории. Именно, что в теории. В моменте-то он может и может, что-то сделать. А вот на чуть более длинной дистанции жидко обделывается.
>>3268497 >А чела, который пишет условные инструменты телеметрии, школьник заменить не может, в интернете нет готовых гайдов как это сделать Заменить-то может и не сможет, но если рассматривать со стороны "кто заказывает музыку" то бабки за работу программиста платит в первую очередь бизнес, а он заинтересован как раз в продукте, который будет ему приносить прибыль. А вот такая "чепуха" финансируется по остаточному принципу, а часто и вовсе под нож идет в случае малейшего кризиса, заменяя их бесплатными аналогами, либо вообще выкидывая нахрен.
Ну а в случае если этот инструмент востребован и успешно продается, то он по сути будет являться тем же продуктом, с той же самой бизнес логикой и всей сопутствующей шелухой под капотом.
Какой есть оптимальный алгоритм для построения дерева?
Типа дерево - обычное, как папки. Я че хочу. Вот у меня есть настройки. Я хочу их представить в виде дерева. Ну, там, /net/wifi/1/name, /net/wifi/1/password Изначально - руками делал, но сейчас настроек дохуя, и я решил, что просто у параметра буду указывать путь, брать из сборки все параметры, и генерировать дерево. Но тут беда. Когда строил руками - можно было полностью узел сконфигурировать, указать иконочку, описание, все это. Но эт решаемо в принципе.
А вот что не вижу как решить оптимально - это то что я не могу гарантировать порядок добавления узлов(типа дочерний узел может быть при генерации дерева раньше родителя, в результате - я чет недоконфигурирую). А значит надо дерево в несколько проходов строить. А я бы не хотел. Хотелось бы, чтобы в один проход как-то пробежаться по параметрам и добавить все узлы и параметры.
Вижу решение в том, чтобы разбить все пути на компоненты, и типа брать, и итерационно - первый слой дерева, второй и так до конца. Но это же тоже не оч оптимально, если узлов дохуя, я просто нахуярю кучу массивов, пусть и временных, которые нужны чтобы найти место в дереве для настройки. Короче. Да. Беда.
Как всё таки не хватает в шарпе подобного синтаксиса возвращаемых значений. Нужно мне к примеру разместить на элементе несколько дочерних. В typescript я просто могу передать эти элементы, а функция может вернуть либо элементы, которые не поместились, либо оставшееся место. Удобно.
>>3268680 А уж как удобно в javascript сделано. Передавай что хочешь, возвращай что хочешь, и никакая типизация тебе не помеха. К счастью, в шарпе есть dynamic.
Есть ли какой-нибудь кодген, который будет метод init в конструктор преобразовывать?
Меня просто откровенно бесит что конструктор совпадает с именем класса. Это просто блядский ужас, особенно когда у тебя дохуя классов называются в духе SomeContext, SomeContextConfig, SomeContextOptions, SomeContextDto. SomeContextRequest, SomeContextResponse, SomeContextWorker, SomeContextService, И да ctor - это не решение. Потому что я код в виме пишу.
>>3268860 >Потому что я код в виме пишу Ктор это дефолтный сниппет. В виме нет сниппетов?
Я себе кастомный сделал — на INPC. В итоге у меня пишется целиком класс с конструктором, реализацией интерфейса, подпиской и регионами и inheritdoc. Все что я делаю, это указываю имя класса и саммари, а оно потом расставляется само в нужных местах.
5 лет опыта бэк разработчик на JS и PHP. Хочется попробовать пересесть на C#, коммерческого опыта работы на нем нет, но есть небольшой опыт разработки личных проектов. Стоит ли пересаживаться? Смогу ли найти вакансии?
На JS постоянно пытаются принудить к фронту, заебало. Я хочу пилить бэк и радоваться жизни, а не с фронтом и всякими Vue/React ебаться. Стоит ли игра свеч?
>>3269599 Если перейдешь на .Net, то особо ничего не изменится. Только уже будут пытаться принуждать к фронту на ангуляре, а не реакте. Чистых бэковых вакансий не так уж и много. Большая часть ищет все того же человека-оркестра
>>3269627 Это зависит от того, идти в галёру или крупную корпорацию. На больших проектах, где по 30+ разрабов, не только не будут заставлять пилить фронт, но и прямо запретят этим заниматься, даже если сам проявишь желание.
>>3269599 >Смогу ли найти вакансии? Без проблем. Только ньюанс в том, что с малым опытом в основном будут вакансии фулкеков, где тебя все равно будут прогибать на js-фронт в виде реакта или ангуляра. Но от пыхи уйдёшь, это да. Потом уже с набором опыта, сможешь претендовать на места в нормальные конторы с читсым бэком.
Если я написал приложение на ASP.NET могу ли я просто арендовать сервер. Установить туда .NET ну и всю лабуду для запуска приложения и развернуть там приложение? Или его надо обязательно поверх IIS или Kestrel ставить? Если только поверх этих веб-серверов то зачем? Могу ли я использовать тот же Apache или Nginx?
>>3270050 Можно собрать самостоятельное Линукс приложение и запустить его, да. Я так на Линукс свой сервер развернул с помощью Apache2. IIS и Kestrel нахуй не нужны для такого.
>>3270050 1. Иис это внешняя хуета, кестрел это билдин хостинг 2. Апач или нжинкс только в качестве реверс прокси 3. Либо ставишь на хост дотнет либо собираешь свой софт как селфхостед дабы не ставить рантайм в ос
>>3270134 CommuntiyToolkit стандарт десктопной разработки, а fody всего лишь кодогенератор, который многократно увеличивает итоговый объем кода. Впрочем в CommunityToolkit тоже есть кодогенератор для этого, но сами авторы рекомендуют использовать его только если нет возможности унаследоваться от ObservableObject.
>>3270142 >CommuntiyToolkit стандарт десктопной разработки кто сказал? ОЧЕРЕДНОЙ фреймворк, который просто от майков.
В отличие от DI от них же, который встроен в asp.net и практически НАВЯЗАН, CommuntiyToolkit просто ЕЩЕ ОДНА ЛИБА на тему.
>а fody всего лишь кодогенератор, который многократно увеличивает итоговый объем кода. упорот что ли? откуда нахрен многократность он всего лишь пишет за тебя то, что написал бы сорсгенератор от того же CommuntiyToolkit, ну или ты вручную Конечно разница есть в итоговом коде, потому что fody большую часть делает на месте без косвенности. но разница это реально мизер. Многократно лол )))
>>3270149 > кто сказал? ОЧЕРЕДНОЙ фреймворк, который просто от майков. Ну ты посиди что-ли в сообществах различных, посмотри, на чем люди пишут. И да, это не фреймворк, это просто набор полезных классов, вроде того же ObservableObject. > он всего лишь пишет за тебя то, что написал бы сорсгенератор от того же CommuntiyToolkit, ну или ты вручную Только он пишет это для каждого класса, тогда как при наследовании один и тот же код переиспользуется. Когда у тебя 10 вью моделек, то может и похуй, а когда их 500 то извините.
Так где тут ананс из ржава треда. В общем диспозиция такая, будучи человеком прагматичным болею за обе стороны в таких делах. Так что успешно пройдя курс по С# решил пройти подобный по Java. Так открыл для себя интересный момент. Код по сишарповски.
ArrayList list = new ArrayList(){1, 2, 5, "string", 7.7};
>>3270153 >что-ли в сообществах различных, посмотри, на чем люди пишут. на всем чем угодно. Просто майки решили "а чего уже существует миллион фреймворков, а нашего нет. давайте сделаем". Они так со многими вещами делают А некоторые люди считают что "вот это стандартное ибо от вендора его и буду юзать". "решение от вендора" != "стандарт". Особенно если оно через 1000000 лет возникло
>а когда их 500 то извините И сколько получишь разницы в этом сферическом конном царстве?
не говоря уже о том что Fody это не только get/set и что он работает и там где ты просто не можешь унаследоваться
>>3270163 Ну так лол, второй пример как раз более читаем для джуна. Я вот смотрю и не понимаю, что за arraylist такой, какого хуя в нем разные типы, словно в жс парашу вступил.
>>3270164 А я и не говорил, что оно стандарт, потому что решение от вендора, оно стандарт, потому что используется в большей части новых проектов. О чем говорить, если та же авалония, изначально построенная вокруг reactive ui в итоге добавила тулкит в стандартные шаблона. Про чисто майковские фреймворки и говорить нечего. >>3270164 >И сколько получишь разницы в этом сферическом конном царстве? 50к строк разницы. По моему более чем достаточно. Не говоря уже о том, что отлаживать такой код куда тяжелее. >>3270164 > не говоря уже о том что Fody это не только get/set и что он работает и там где ты просто не можешь унаследоваться Ты жопочтец, да? >>3270142 >Впрочем в CommunityToolkit тоже есть кодогенератор для этого, но сами авторы рекомендуют использовать его только если нет возможности унаследоваться от ObservableObject.
>>3270185 >новых проектов это десктоп. тут новых проектов раз и обчелся. разве что всякие новички, которые не знаю что выбрать и поэтому выбирают "от вендора"
>добавила тулкит в стандартные шаблона и что? а ничего
>50к строк разницы каких строк????
> отлаживать такой код куда тяжелее в чем тяжесть?
>>3270120 Ну как? Сначала ты создаешь конструктор базового класса, а потом конструктор наследника. Это минус производительность. Не сказать, что грандиозная, ну так и лишний код надо с лупой искать. Короч, пытаться такое оптимизировать — лишняя суета.
>>3270185 я тебе так скажу все говно, ведь нативно не поддерживаются лайфтаймы. А значит привет закат солнца вручную. либо пиши проекты с 3.5 вьюмодели.
>>3270323 1 председатель? Да, это набор разных либ. но конкретно там где ObservableObject это часть MVVM, которые в миру называются MVVM фреймворки. Но ты можешь взять табуретку
2 Типичные для всех MVVM фреймворков - поскольку они опираются на WPF, то у них проблема со стронг подписками. Они даже сделали мессенджер стронг, но проблема отписки "ну вы там сами ребята как нибудь костыльте, наши полномочия пук среньк"
ну и кодогенерация свойств говно, но это уже неважно.
>>3270328 > 2 Типичные для всех MVVM фреймворков - поскольку они опираются на WPF, то у них проблема со стронг подписками. Они даже сделали мессенджер стронг, но проблема отписки "ну вы там сами ребята как нибудь костыльте, наши полномочия пук среньк" Вообще-то мессенджер там по умолчанию использует слабые ссылки.
>>3270331 так я это и сказал. но сам подход со слабыми ссылками говно. что признают даже авторы и создают стронг решение но толку от этого чуть менее чем пук среньк
>>3270409 Не часто. Обычно нужно самому под это подписаться/спалиться, что знаешь WPF. Просто заставлять жисоноукладчика писать десктопные приложение это крайне расточительная затея, т.к. для начала нужно будет его научить WPF и вообще разработке десктопного софта, так как это все достаточно сильно отличается от типичного крудошлепства. Дешевле просто нанять специальных скуфов, которые уже 10-15 лет с ним пердолятся.
За три года работы якобы "программистом" впервые недавно встретил проблему с DI и скоупом и жидко обосрался, прося сеньора помочь Там вроде из-за того что запрос не был вручную в scoped DbContext не успевал завершиться и уже другой запрос начинался, а он мультипоточность не поддерживает (ну насколько я понял в чем была проблема) Я собственно пошел в гугл и в чатгпт, там и черным по белому написано юзай DbContextFactory, что и решило проблему Но сеньор сказал что это хуйня и надо обернуть сервис вручную в scoped через IServiceProvider Потом только вспомнил что просто регнуть DI в Program.cs можно в вебе, в консольных каких-то приложухах надо вручную оборачивать хендлер или сервис
В общем, я осознал что я -- хуй, которому еще много и много учиться, и что три года опыта моих -- говно Ну и не удивительно, на первой работе я шлепал дерьмовые бизнес-процессы на low-code платформе, и более-менее кодить нормально (с гитом, докером, тестами и прочим) только около года назад, и то сейчас это в основном работа с файлами и примитивные апишки Ни async, ни микросервисов, я даже SQL то не пишу на работе, все через EF
>>3270463 >Но сеньор сказал что это хуйня и надо обернуть сервис вручную в scoped через IServiceProvider Ну раз сказал, так и надо было его припрячь, чтобы он показал как. А заодно и пояснил чем конкретно его контекст-фактори не устроил. Просто в бытность мою джуном часто сталкивался, когда сенька тебе на ходу говорит, что нибудь вроде "хуйня_нейм_1 тут не подойдет, делай хуйня_нейм_2", а после того как ты неделю пропердолишься, чтобы это сделать, смотрит и "не, чет я маху дал, хуйня_нейм_2 тут не подходит, верни как было" >>3270463 >я даже SQL то не пишу на работе, все через EF Ну так заебись же. Я вот охуенно рад, что у нас на текущем проекте прям запрет на использование в коде sql или хранимок. Только в исключительных случаях, если совсе без этого не обойтись.
>>3270522 >>3270522 >Ну так заебись же. Я вот охуенно рад, что у нас на текущем проекте прям запрет на использование в коде sql или хранимок. Только в исключительных случаях, если совсе без этого не обойтись. Так хочется работу сменить, ибо платят 90к, и везде требуют опыт работы с ним, и еще разработку архитектуры Не, можно и самому задрочить, но я не знаю насколько онлайн задачки приближены к реальности >пояснил чем конкретно его контекст-фактори не устроил Ну типа зачем плодить фабрику когда можно вручную просто обернуть, якобы и код небольшой, зачем инстанс на каждый новый запрос создавать
Рейт нубаса, хочу простой сервер свой блять! Чтоб чатик был, итем трейдинг, вот это вот все. Вот че смог за 4 дня сделать. До этого вне юнити никуда не ходил, ваще не ебу че такое фактори, или скоп или транзиент. Вообще я нахуй нетворкинг длинной палкой даже не трогал. Чатик заработал, регистрацию-логин запилил по юзер пасворд. Заебись. С каждым пуком от клиента я отправляю JWT токен чтоб понять кто пишет. Это нормально нахуй?
Важно чтобы сервер работал через вебсокет онли, потому что юнити вебгл билд не поддерживает прямой хттп. Ну то есть поддерживает но нужно `Cross-Origin Request` разрешения или че блять???. Я ебу не осилил.
Ну значит какие готовые решения есть для вебсокет? - Mirror для юнити. Но это пиздец, там бекенд и клиент это один билд нахуй. Даже я нубас чую что это немношк неправильно. То есть на сервере будет крутиться юнити билд. Кароч это решение больше для п2п сделано. - Colyseus. Там бекенд кодится на Node.js typescript. Фу нахуй, фу блядь. Я попробовал не осилил. Архитектура там нагромождено в виде комнат. Слишком намудрёно для моего юз кейса, я не фпс мультиплеер делаю, я больше делаю сайтик но на юнити. Понимаешь? - SignalR. Вроде взрослые дядьки этим делают бекенды. Но, клиент сигналр не встал на юнити, сигналр без хттп не работает чтоли? Ну хуйли делать, очень намудрёно там тоже, я нихуя не понял. - SimpleR. Вот это находка, SignalR, только урезанный. Клиент не нужен, можно тупо по голому вебсокету общаться. Вот на нем и сделал че сделал.
Шарпаны, помогите. Какой есть примитив синхронизации типа: если число больше нуля - поток может войти, если равно нулю - ждет. НО, чтобы не семафор, потому что семафору надо задавать кокретное число, и соответственно следить, чтобы ты не попробовал ресетнуть семафор.
В общем. Что мне надо. Мне надо, чтобы поток ждал, пока в очередь кто-то что-то не положил. Как только кто-то положил - он должен это достать. И обрабатывать всякое до тех пор, пока в очереди что-то есть. Т.е. другие потоки - должны при записи какой-то счетчик увеличивать. А потоки обработчики - при чтении - уменьшать. Ну или как-то так. Я короче не шарю. Задача в следующем. Много потоков пишут в очередь. Чуть меньше потоков - читают из нее и обрабатывают. И вот как добиться такого поведения, не скатываясь в : while(!TryDequeue(out item)) {Thread.Yield()} - я придумать не могу.
Про каналы я знаю, но в моем кейсе - они немного не подходят
>>3271267 >while(!TryDequeue(out item)) Ну по факту это и есть тот самый примитив который тебе нужен. Все что сложнее все равно по сути на этом и строится. Посмотри например библиотеки типа ConfluentKafka, там при чтении из очереди в Consume по сути тот же самый while будет, только с обработкой таймаута и токена отмены.
>>3271267 не подходят потому что ты жаждешь стрелять себе в ногу желая чтобы у тебя была гонка за "это мое из очереди" Вместо того чтобы "много кладут, забирает один и обрабатывает в заданном количестве воркеров так сказать". Канал + семафор или костыли в виде очереди + WaitHandle + семафор
это абсолютно разные направления где суперспец в любом из этих направлений является абсолютным нубом в любом другом. Настолько оно всё разное. Ну да шарп и что. Все остальное кардинально отличается.
>>3271797 В гд кста от слова нетворкинг они в штаны наложат. Нехуй там ловить. >>3271823 Буду бля экспертом во всём. Жек оф ол трейдс, хуй вы меня остановите. Я заключил что мой подход вполне приемлим, протестировал подключение из разных мест, платформ и хостингов. Робит норм, а хули мне еще надо. Заделал ссл сертификат и стал валидным. Чем вы тут вообще занимаетесь тогда? Теоретики кукаретики?
>>3271831 я эксперт во всем 1 я эксперт в десктопах. основной мой хлеб 2 я эксперт в бэкенде. поскольку раньше писал под веб на других языках, то понять что там где мне было легко 3 я эксперт в юнити. я его пощупал и стал экспертом с пониманием "фуу это говно мне не надо"
>>3271833 >я эксперт в десктопах Хули там быть экспертом, это же база самая. >я эксперт в бэкенде О! Нашел кого надо. Ну подскажи где я проебался. И почему SQLite в продакшене это база нахуй. >я эксперт в юнити. я его пощупал и стал экспертом с пониманием "фуу это говно мне не надо" Звучит как будто ты нихуя не эксперт и не понял смысла, посыла сего творения. Я понимаю что оно нахуй тебе не упало три де модельки крутить и шутеры делать, но экспертом себя называть это сильно выёбисто.
>>3271837 >это же база самая. угу угу. все так говорят. пока не попробуют. Ну или пишут херню в финформс стиле. >И почему SQLite в продакшене это база нахуй потому что она локает всю базу при записи. И ты легко можешь получить database locked при многопоточной записи и при любом значении таймаута. Я правда не знаю как с мссклайт дело обстоит, но с обычным адаптером его политика "о занято, я зайду попозже" приводит к тому что когда бы он не зашел всегда занято и в итоге выпадет по таймауту. Банальный семафор конечно поможет, но где ты его видел в доступе к бд... >экспертом себя называть это сильно выёбисто я не говорю что я знаю юнити на уровне эксперта. Я говорю что на меня снизошло понимание держаться от этого подальше. И это знание делает меня экспертом тяжко тебе без чувства юмора
>>3271858 Я ожидаю максимум сотню человек одновременно онлайн. Думаю склите справится. Че за семафор? Звучит как бренд фильтра кувшинного. >я не говорю что я знаю юнити на уровне эксперта >это знание делает меня экспертом Очень бля смешно, юмор у вас дебильный, господин эксперт. Хаха ебать, фреймворк который нужно изучать годами, не хочу его изучать, ебать я умный.
>>3271867 >Думаю склите справится Да, делай, ни о чем не думай. Еще рекомендую сделать журнал в памяти, быстрее будет
>Че за семафор? Семафо́р — механическое средство сигнализации для подвижного состава на железных дорогах. Семафор состоит из металлической мачты, несущей одно, два или три сигнализирующих крыла и сигнальные фонари. К крыльям семафора во многих системах сигнализации жёстко прикреплены светофильтры со стёклами различных цветов
>фреймворк который нужно изучать годами я, как разбирающийся в вопросе использования юнити на экспертном уровне, говорю что "нах он вам не нужен, не лезьте в это дело" но лично тебе рекомендую освоить его на 1000%
суп аноны. Сижу учусь вашему сишарпу и так вышло что надо было написать юнит тест для метода контроллера, который асинхронно обращается к бд. Начал гуглить, нашел моки, вроде понял, начал писать и пиздец, он работает, но сыпется когда я вызываю ToListAsync, пишет что не нашел его реализацию в моке если я правильно понял. Суть в чем, пока я искал инфу, часто натыкался на советы что вообще не стоит тестировать так EF. Вопрос Стоит ли вообще дальше упарываться в эту хуйню на скринах код которые работает только синхронно
Я заебался с EF. Решил для домашнего проекта - делать без него, как в древности: папка с SQL скриптами, и погнали. И теперь я уже с этим заебался, потому что папка раздувается и раздувается. Дополнительно, я должен как дурак при добавлении скрипта - идти и в коде добавлять теперь как с ним работать.
Возникла безумная идея, а шо если добавить скриптам комментами мета-информацию, в духе: че это за скрипт, с какой сущностью он работает, какую операцию выполняет. Тогда я смогу при старте - всю эту хуйню достать и просто дергать эти скрипты.
Но тут уже возникает другой момент - а нахуя, блядь, мне с этой залупой маяться и почему-бы не вернуться к EF.
В общем, если есть те, кто в реальных проектах без ОРМ обходились, расскажите, как в это дело ментейнили, как не скатывали все это дело в хуйню, что одна таблица новая появляется - беги в 100 местах поправь и вот это вот все.
>>3273081 > как в это дело ментейнили, как не скатывали все это дело в хуйню, что одна таблица новая появляется - беги в 100 местах поправь и вот это вот все. Да легко, запросы пишутся прямо в коде в строках, но выносятся в DAO-классы, которые везде и юзаются, а в отдельных файлах только скрипты миграции для изменения схемы. В 100 местах ничего править не надо, только в DAO, ну и в отчётах, которые и так обычно пишутся на чистом SQL даже при наличии ORM.
>>3273081 Просто используй Dapper. Просто пишешь сами скрипты внутри методов DAO/репозитория, а Dapper выполняет за тебя весь бойлерплейт по маппингу их результатов на объекты. Можешь ещё в сторону Linq2Db глянуть. Он менее магичен чем в EF-e, так как в нет Change Detector-а и автогенерации инсертов, апдейдотов. Но он позволит так же, как и EF, один раз прописать все маппинги между классами с их свойствами и таблицами с полями, и юзать IQueryable для запросов.
>>3273081 >В общем, если есть те, кто в реальных проектах без ОРМ обходились, расскажите, как в это дело ментейнили Никак. Мы прекратили страдать хуйней и научились нормально пользоваться ORM, в частности EF.
>>3273081 Если вопрос про управление схемой бд: FluentMigrator, DbUp. Если про замену ef для работы с базой: linq2db, dapper, можешь посмотреть ещё SqlKata (билдер запросов, работает поверх даппера)
С тех тех пор как стал их использовать - впервые почувствовал что ИНОГДА, таки - разделять объявления и реализацию даже может быть удобно. Потому что ну вот хочется чтобы объявления вложенных классов были где-то вверху, но вот когда они таки вверху класса, сам основной класс становится тяжело читать.
Пока что решаю это костылем с partial. Вверху - делаю "объявление", внизу - реализацию уже. Но все равно выглядит костыльно.
Всех приветствую, у меня два вопроса. 1)Что вы используете (чаще всего) для работы с Базами данных? Чистый SQL, Entity Framework, Entity Framework + LINQ
2) Что используете или с чем чаще всяко сталкиваетесь как back-end разработчик, при написании Frontend? Чистый html/JS/TS/CSS или фреймворки Razor/Blazor или что то другое?
Заранее благодарен тем кто поможет ответом. Сам я недавно вкатился в C# с другого языка (в web плохо шарю) поэтому просто хочу понять на какой стек делать упор.
>>3274320 >Entity Framework, Entity Framework + LINQ Entity Framework без LINQ это как? >чистый SQL вопрос должен был стоять какой орм кроме EF. Ибо никто чистый ADO.NET не использует. вот я Dapper, но это не значит что я не использую LINQ. sql ведь можно сгенерить из LINQ. Почему то многие об этом забывают. Почему не Linq2Db? Да блин бывает проще собрать sql другими способами, чем сломать мозг и выразить в LINQ
>на какой стек делать упор. тебе выбирать орм не приходится если планируешь работать на кого то. Придется изучить EF ибо как бы типа стандарт.
>>3274320 >1)Что вы используете (чаще всего) для работы с Базами данных? >Чистый SQL, Entity Framework, Entity Framework + LINQ Для работы с БД - EF. А LINQ - вообще всегда, при работе с коллекциями, независимо от того, связано это с БД или нет. LINQ - это вообще одна из самых наипиздатейших вещей.
>2) Что используете или с чем чаще всяко сталкиваетесь как back-end разработчик, при написании Frontend? С React'ом.
>>3274390 >бэк на С#, а фронт на JS React? А что не так? На быке ты выставляешь наружу универсальное API и можешь тыкаться в него хоть чем. Реактом, ангуляром и даже vue, какой-нибудь ios-овской хуйней или универсальным десктопом. Мне за последние 5 лет только реакт на проектах и попадался. А иногда я даже в принципе не ебу, что там конкретно под капотом. Просто согласовываю контракт с фронтендером и все. А если нужно локально фронт развернуть, то npm install и npm run все что мне нужно. >>3274390 >а почему на Blazor например? Потому что: - хорошего фронтендера на js стеке найти намного проще, чем хотя бы просто нормального на блазоре. - если делать на блазоре, то будет очень жесткая привязка к стеку - блазор сам по себе мутный и не факт, что майки в ближайшее время не скажут "нам надоело, дальше ебитесь сами"
через Entity Framework создал базу данных в Postgres через фреймворк могу получить данные захожу через psql база данных есть, таблица есть но самих данных нет что я делаю не так?
>>3274730 сделал причем сама база данных и таблица создается, но она отображается пустой. Считать через EF я могу но захожу через psql select * from User; и там данные в базе не отображаются
>>3274734 Ну тогда проверь, что ef и psql коннектятся к одной и той же бд, читают из одинаковых таблиц. Наверняка из-за невнимательности где-то опечатался.
>>3274645 Проверь к той ли ты БД и под тем ли же пользователем ты подключаешься, что и в ef. Попробуй не через PSQL это делать, а через PgAdmin или через DBeaver.
Я правильно понимаю, что такой класс - хуита, потому что предотвратить использование типа Yoba<Foo, Foo> не выйдет, только в рантайме из конструктора выбросить исключение?
я условно неофит в C# впервые столкнулся с проблемой "балансировки" пакетов и библиотек вообщем надо создавать приложение в контейнере (Docker) в целом я начал уже изучение этой технологии Правильно ли я понимаю, что мне надо загрузить образ мой ОС (Ubuntu) создать на основе ее контейнер и туда загрузить уже .dotnet, все фреймворки -- я к тому что там же пипец дохера всего надо а IDE как через IDE в контейнере работать или саму процедуру не так понимаю и это делается по другому
>>3274872 ну а как еще. ну ты можешь потребовать "реализуй этот интерфейс и тот интерфейс". но никто не запрещает реализовать их оба одним классом (в этом и суть интерфейсов) Так что да - в рантайме и все. И даже это лишнее - пусть клиент решает что пихать, а если он дебил, то у него работать не будет.
Кто-нибудь, пж обьясните, почему именно на C# такие ебанутые требования в вакансиях и на собесах какие-то чсв-красноглазики сидят и пытаются самоутвердиться
Типа, весь питоновский стек на аналогичные позиции проще, чем один .NET, без ASP.NET, EF и т.д.
А тут большинство еще себе фуллстека хочет, причем на зп, наже чем у обычного фронта
ЧЗХ с шарпом случилась, технологоя же приятная и хорошая, да и вкатунов нет, почему на том же питоне и JS, где вайтишники должны были просадить зп, вилка куда лучше, чем на шарпе?
>>3275909 .NET(GC, CLR, async/await, DI) ну и естественно всякие вопросы со *, типа интернирования строк ASP.NET Core ASP.NET MVC SQL EF Core Docker CI/CD RabbitMQ/Kafka Blazor grafana prometheus .. . . Это только бэк, а обычно ищут фуллстеков, а там добавляется HTML, CSS, TS, Angular
>>3275963 ASP.NET MVC тоже не совсем бек, CI/CD и остальное - DevOps, хз для чего им на бэке это всё, но да, на многих вакансиях это на бэк либо требуют, либо "желательно знать"
>>3275979 По твоему фронты только вёрсткой занимаются? Да и сам паттерн MVC - фронт
Судя по всему им нужен: напиши тесты, напиши код, спроектируй и оптимизируй БД, разверни семейство контейнеров с балансировщиками нагрузки и настрой авторазвёртывание
Хз че в таких отделах по-факту происходит, я решил, что нахуй ASP.NET, буду в питон валить, вакансий в 3 раза больше и они в 10 раз адекватнее
>>3275998 >Да и сам паттерн MVC - фронт никоим образом. моя обязанность, как бэкендера, выдать на фронт нужное. А как оно там будет работать - не моя забота. А выдаю я данные апи или готовый хтмл - разницы особой нет если не моя забота чтобы эти данные или хтмл использовались как надо. Я всего лишь выдаю что надо и не более.
>>3277086 что вместо блазор? React? а Razor Pages знать надо? Просто все туториалы которые смотрю на ютубе (вышедшие не раньше года) там везде Razor хуярят
>>3278184 Ну, я изначально имел второй метод, который как раз был для того чтобы через лямбду сконфигурировать. Но опять, у меня в конфигурации лежит тот самый обработчик моей "роботы" и я потому пришел к тому, чтобы явно делать отдельные классы с конфигурацией, в них сразу лежит обработчик.
В общем. Сейчас чуть подумал и решил таки ебнуть через рефлексию. Сделать метод services.AddMyWork<TWorkTypeConfig>() Который будет определять, какую же работу этот конфиг делает, создавать инстанс конфигурации и передергивать уже services.AddMyWork<TWorkType>(WorkConfig<TWorkType> config)
Но немного боюсь что где-нибудь обосрусь и будет не оч надежно.
А как сделать "первый запуск"? Вот ко мне доебался клиент, что ему не хочется в appsettings прописывать подключение к базе. Я сначала отнекивался, дескать - та че такого, так везде, а потом он показал женкинс и другие программулины, у которых при первом запуске тебе форма для ввода всех настроек для первого запуска, включая имя одмена и прочее выскакивает, и после того как ты настроил - оно только нормально стартует. Я чет охуел. Но теперь чувствую себя попущеным и ущемленным, хочу сделать чтобы и у меня в программулине так же было. Кто-нибудь делал? МБ есть готовые пакеты, чтобы организовать этот первый запуск?
>>3278195 >, создавать инстанс конфигурации и передергивать уже если у тебя на каждый TWorkType свой уникальный TWorkTypeConfig то ты просто выдумываешь себе проблему да даже WorkConfig<TWorkType>
простое добавление этих вещей в контейнер и доставание их в конструктор - штатный способ работы с зависимостями. (и их переопределением). Хотя можно сделать как с IOptions то есть доопределять
>>3278210 Не усложняй если мы говорим про десктоп. Делается банальный сплеш/лоадер скрин то есть просто окно где все инициализируешь - ну а потом стартуешь основное окно. Делов то.
>>3278221 У меня сервер для работы с IoT железками. Сверху прикручена веб-морда, чтобы адменить это дело и статистику смотреть, права доступа к железкам настраивать, логи там, сколько трафика насрали железки и все такое.
>>3278223 ну какая проблема если не задан конфиг то выбросить хтмл простой где это все ввести и если все нормально редиректнуть на основное веб приложение. Поскольку в самом веб приложении это может быть сложновато делать.
>>3278265 знать бы на что мы смотрим но видим бррр зашитые пути AppDomain... хтмл выдаешь как файл. есть же статикфайлы пробелы вместо табов. и бррр. жаваскрипт
>>3278362 Ну, я решил хуйнуть вот такой вот способ "первичной настройки". Проверяю, что не выполнена перавичная настройка, создаю на рандомном порту хост для настройки, запускаю бравзер на нужной странице, отдаю форму с настройкой. Дальше буду сохранять эти настройки и уже нормальный хост остального приложения запускать на правильных портах и со всеми остальными настройками.
Так всрато, потому что просто проверить, что это работать будет. Дальше я прикручу нормальный реакт. Пути все равно буду из аппдомена брать, потому что конфигурации до того как ее первый раз выполнили нет, а тащить MVC'шные контроллеры с вьюхами не хочу.
>>3278195 >Но немного боюсь что где-нибудь обосрусь и будет не оч надежно. Если боишься, что обосрут из-за рефлексии, то просто посылай всех нахуй. В твоем кейсе - это будет делаться один раз на старте и ты максимум несколько микросекунд задержки получишь. Единственное, что в таком случае действительно стоит делать, это выносить такие расширения в отдельный подпроект, чтобы вся лапша связанная с рефлексией и добавлением была скрыта за internal, а наружу в твою основную сборку торчал бы только основной метод расширения. Алсо, насчет надежности, используй неймспейсные якоря и констрейны, чтобы рефлексией вытаскивать именно то, что тебе нужно и не цеплять лишнего.
Делаешь провайдер настроек, который проверяет, есть ли в приложение настройки тупо возвращает true/false Делаешь middleware, который просто делает запрос к провайдеру - если настроек нету, просто делаешь redirect на страницу с базовыми настройками.
Почему по шарпу просто нет нормальных обучающих материалов? Нет курсов по asp.net, нет гайдов, нет статей. Все ресурсы полудохлые, документация просто кусок говна, самый отвратный нейминг, который только существует на данный момент. Почему так? В той же джаве всё просто в разы лучше. Хотел перекатиться в бэк с написания десктопного кала, думал лучше будет мне вкатиться в .net, раз уж мне шарп давно знаком, но я просто охуел с того насколько всё плохо. Ещё и большинство вакух на .net это каловый фуллстек, чего опять-таки нет у жабы. Может я просто не понял прикола?
>>3279207 Это заговор. Все фулстековые вакансии на самом деле и есть бэк, но устроиться на них могут только те кто знают секретные фразы и правильные ответы. А обучающие материалы есть только в печатном виде и передаются только из рук в руки по наследству.
>>3279207 Не родился в семье потомственных шарпистов? страдай теперь )
Кстати про нейминг это синдром утенка. Чисто дело привычки. Говорю это как полиглот с десятком языков (из которых активно использую 4, а еще 2 приходится, но лучше бы не видеть. Но там не проблема нейминга. Там проблема что это похапэ наследие и богомерзкий жс)
>>3279374 >Кстати про нейминг Может он имел в виду нейминг версий платформы/фреймворков/библиотек и т.д. Вот тут да, даже самые упоротые биллибои признают, что нейминг продуктов у майкрософта - кал говна. Что у винды, что у консолей, что у любого их софта. Ну а с .Net-ом с его FrameWork/Standart/Core и т.д. крайне легко объебаться и воспылать ненавистью.
>>3279483 >FrameWork/Standart/Core и т.д. крайне легко объебаться принимается. но все же если знать историю и не смотреть на легаси то проблем нет. но все же это не сяоми - вот уж где нейминг
Пацынки, как RPS посчитать? Мб есть что то готовое? Что я имею в ввиду. Есть у меня код он работает в 200 тасок. И хочу узнать сколько примерно в секунду раз выполняется этот код. В частности на последем этапе я просто считаю количество успешных выполнений делаю ++ вот так using (StreamWriter writer = new StreamWriter($@"zalupka/{Guid.NewGuid()}.html")) {
Как настроить копирование нативной библиотеки в зависимости от ОС? RuntimeIdentifier работает только для publish, но не работает для обычного билда (build) и так же не работает, если запустить в самой студии билд. Как правильно это всё настроить?
>>3220909 Врываюсь с ответом на древний пост, потому что невозможно уже терпеть тупость, которую тут пишут:
>Экспрешном - это будет одна строчка. Квери - это будет дохуя строчек. var user = (from u in context.Users where u.Id == 2 select u).FirstOrDefault(); var user = context.Users.FirstOrDefault(u => u.Id == 2);
>пока все переберешь, пока всем переставишь статус. context.Users.ExecuteUpdate(u => u.SetProperty(u => u.Status, false)); Будет сгенерирован такой же точно код типа UPDATE Users SET Users.Status = ... и больше ничего.
>>3278665 1. Пошел нахуй, сразу 2. Таким ебаным стилем никто квери не пишет. Если ты такой оригинал - можешь вообще, весь код в одну строку хуярить, хуль. 3.Вот эти твои ExecuteUpdate/Delete - появились только в 7м EF, чел. Как-бы я не знаю, понимаешь ты или нет, но есть просто дохуища кода, который есть, работает, и написан ДО того как какая-то залупка появилась в EF
>>3280714 >Как-бы я не знаю, понимаешь ты или нет, но есть просто дохуища кода, который есть, работает, и написан ДО того как какая-то залупка появилась в EF Стоит по возможности избегать работы с древним дерьмом.
Алсо, ты не туда ответил, твой ответ вот сюда: >>3280711
>>3280714 >Таким ебаным стилем никто квери не пишет. Протри глаза от спермы, вопрос был не в том, что можно весь код в одну строчку занимают, а в том, что экспрешен короче для простого запроса.
Для тебя: var user = (from u in context.Users where u.Id == 2 select u).FirstOrDefault();
var user = context.Users .Where(u => u.Iq > 80) .FirstOrDefault(u => u.Id == 2);
Экспрешен здесь даже длиннее будет.
>ДО того как какая-то залупка появилась в EF В своем энтерпрайзе на Web Forms пишешь? Отсюда и тормоза, что макаки не следят за модными залупками и хуярят инсерты в циклах. Два года уже седьмой версии.
>>3280726 >а в том, что экспрешен короче для простого запроса Не тупи, посчитай число символов просто Я даже тебе строка к строке приведу
var user = ctx.Users.FirstOrDefault(x=>x.Id == id); var user = (from u in ctx.Users where u.Id == id).FirstOrDefault();
А дополнительно - второй запрос - хуже читается.
Квери ок, когда реально сложный запрос, который через экспрешены составлять больно, те же сложные джоины, многоуровневые группировки. В остальных случаях - fluent предпочтительнее.
Оказалось можно не дрочить .csproj и публиковать отдельно, благодаря обрезки удалось для хеллоу ворда уменьшить с 70мб до 11мб Не гошка, но уже неплохо. Конечно без ЕОТ AoT
манит меня геймдев в ваших дотнетах, но как же все это избыточно и прибито к vs, ппц. Если стану дотнетчиком - нужно будет покупать дилдак и красить волосы в синий?
Назло джавистам? Ну реально невозможно читать. Кто-то вообще пишет на этом в проде обычный нормальный код с 1тбс и пробелами как положено, как это везде делают?
>>3280751 >Ну реально невозможно читать. Ну не читай, чо. В чем проблема. Коды писать нужно, а не читать.
Алсо, сам работал как-то год в команде из бывших джавистов, которые притащили в шарповый код свою расстановку скобок. Где-то через неделю становится абсолютно похуй где там эта первая скобка на новой строке или на предыдущей. В шарпе к тому же достаточно сахара, чтобы от процентов 70-ти скобок вообще избавиться.
С пробелы vs табы, абсолютно таже хуйня - спорт для дебилов. В IDE вообще похуй, я даже не знаю что у меня там на текущем проекте, все что нужно в .editorconfig-е прописано, я просто тапаю кнопочки, оно само расставляет как надо.
Вот когда пробелы/табы делают элементом синтаксиса языка как пайтоне - вот это действительно пиздец.
>>3280751 Изначально так было в плюсах, по крайней мере так учили меня в девяностые. И это было логично открывающая скобка на той же линии что и закрывающая. Это потом я переполз в жабу и реально плевался. Мой внутренний перфекционист тогда был просто убит. И сейчас я напрочь привык стилю из жабы, но понимаю людей с олдово-правильным стилем.
Так что забей, вложенный код читается, имхо, быстрее с такими отступами.
Пони, что вопрос не про сами шарпы, а софт. Но что, кроме студии, можно использовать для написания софта. Просто студия - меня в конец подзалюбила. Слишком тяжеловесно на солюшинах, где хотя бы 100 проектов. Все кайфовые штуки начинают уже не так кайфово работать, за рабочий день - раз 5 вылетает, тупит, пердит и тормозит.
>>3281457 >Но что, кроме студии, можно использовать для написания софта. Райдер, VS Code, для особых ценителей Vim Только я уверен, что любой другой софт у тебя будет вести себя плюс-минус так же с твоими проектами, если прогружать все символы и задействовать intellisense-функционал на полную. Там скорее всего упор уже идет в ресурсы твоего компа.
>>3281657 Поч монолитом? 40 микросервисов, разбитых по клин архитектуре, плюс либы общие. Все в одном солюшне, чтобы УДОБНЕЕ БЫЛО. Типа, ну вот майки половину своих хуйнь на эти солюшины завязали, те же нугет-конфиги, чтобы нормально работали - должны рядом с солюшином лежать, ну и т.д.
>>3281713 Ну. Хм. У меня 64гига оперативки и i9 на работе последний. Но студия - пердит, тормозит и вылетает.
>>3282258 >Все в одном солюшне, чтобы УДОБНЕЕ БЫЛО Монорепа короче. Хуево быть вами. >Ну. Хм. У меня 64гига оперативки и i9 на работе последний. Но студия - пердит, тормозит и вылетает. У меня 32гига с i5-12. Бывает штук по 5 студий в каждой из которых проект с 15...20 подпроектами открываю и нормально все крутится. Попробуй чекни и поотключай всякие анализаторы кода и т.д. Плюс проверь расширения, некоторые бывают очень много жрут, запуская анализ на каждый пук при редактировании. Например какой-нибудь банальный спелчекер может дохрена отедать. Плюс может еще у тебя ССД-шник медленный (ну или ты вообще оригинал и на обычном винте проект держишь)
И кстати если у тебя i9 13-го или 14-го поколения, то для тебя плохие новости - эти процы сами по себе еще деградируют быстро под нагрузками. Так что дело может и не в студии вовсе.
>>3218902 (OP) Взяли на стажировку С# кодером, а я не кодил уже год, надо будет за воскресенье как-то вспомнить это дело. Сказали правда что склом в первый день загрузять и хмлом
>>3283558 >каждый сервис в отдельной ide запускать, чтобы проект поднять локально Во первых, зачем? Открываешь только те над которыми непосредственно работаешь или которым нужна отладка. Если у тебя действительно микросервисная архитектура, то необходимость работать одновременно более чем с парой-тройкой сервисов будет очень редким кейсом. А все остальное либо запускается отдельно без всякой студии, либо в контейнере, либо напрямую, либо на стенде.
Если же у вас действительно при работе над одним из сервисов приходится приходится копаться в кишках всех остальных, то сорян, но тебя наебали, нифига у вас не микросервисная архитектура, а хуета какая-то. Просто монолит размазанный тонким слоем.
Во вторых как ты собираешься нормально одновременно запускать 40 разных сервисов в одной студии одновременно, это звучит еще ебанутее.
А как правильно хранить перечисления в бд? Например, у меня есть перечисление, которое является полем в классе User: public enum Role { Admin= 0, User= 1, } По умолчанию, если просто сохранить юзера в бд, то будет инт (0 или 1), как я понимаю, можно еще переопределить, чтобы сохранялось строкой(Admin или User). Или можно создать отдельную таблицу для ролей и использовать внешние ключи. Как правильно и как принято?
Пишу десктопное приложение, и мне хочется максимально ускорить его запуск. Обычно требуется порядка 10 секунд чтобы проинициализировать все сервисы и проверить БД на необходимость миграции. И я решил переместить инициализацию сервисов в логику самих классов, получился пик. Насколько такое решение имеет место быть?
>>3283698 Хуйню придумал. Потом заебешься, когда окажется, что что-то должно за чем-то инициализироваться.
Делай нормальную Lazy-инициализацию. Если твоему приложению реально нужны на старте ВСЕ те сервисы - то просто сделай сплешь-скрин с индикатором загрузки, пользователь поймет. С вероятностью 99% твоему приложению прям на старте - все сервисы и не нужны в проинцициализированном состоянии. А потому - найди то что прям реально надо чтобы было проинцизиализировано, остальное - начинай инициализировать после того как первый экран отрисовал.
>>3283698 Сверху. Твой класс - будет доступен уже другим сервисам, будто все ок. А он не проинициализирован. И либо тебе как ебанату придется в каждом месте вызова проверять, а прошла инициализация чи нет. Либо скрестить пальчики и надеяться что не упадет.
>>3283705 Да, все не нужны, но как определить, когда будет нужен тот или иной сервис? Условно другой разработчик добавит в конструктор класс, требующий инициализации, и что тогда? (У меня все модели представления добавлены в DI контейнер, при загрузке вьюшки я прямо в ее конструкторе получаю вью модель и присваиваю ее датаконтексту.) >>3283709 Так в примере же видно что в каждом методе будет проверка инициализации. Правда тогда все свойства придется заменить на GetPropertyAsync, а это уже попахивает.
>>3283698 > Обычно требуется порядка 10 секунд чтобы проинициализировать все сервисы и проверить БД на необходимость миграции делаешь окно "загружаемся" ака сплешскрин но вообще нах выбрасывается EF и получаем мгновенную загрузку.
>>3283669 В связке пг+еф есть возможность сделать что юы тип колонки ставился как энам тип, но на практике это лишний головняк и юзется обычная числовая колонка. При желании для энама в шарпах можно указать : byte/short или другой тип что бы меньше места занимало
>>3283698 В общем задал вопрос чатгпт, она подсказала вариант с использованием фабрики. Т.е. вместо сервиса я запрашиваю в конструкторе фабрику, которая имеет асинхронный метод GetServiceAsync. В целом это кажется более чистым вариантом. Хотя опять же, при таком подходе мы по сути подгоняем интерфейс под конкретную асинхронную реализацию.
Хм. Ну, вот решил я на выходных от нехуй делать микробуру запилить. И вот ну, я сижу такой, и не понимаю, а почему не в контроллере это вот все делать. В упор. Типа, во-первых. Если делать сервис, придется уже не IFormFile а стрим по нормальному передавать, ведь сервис не должен же про HTTP знать и всю хуйню. Во-вторых, тогда и EF надо выпиливать, ведь слой приложения не должен знать про инфраструктуру, азаза. Короче. Я к чему. К тому что чет проснулся утром и понял, что это какой-то онанизм ебаный. Надо будет - вынесу в сервис, а не надо - так нехуй придумывать себе работу, которая нахуй никому кроме твоей шизы не сдалась. Такие вот дела.
>>3284690 У нас примерно так же рассуждали, типа надо будет - сделаем. А потом вдруг возникла необходимость иметь два разных набора контроллеров, вызывающих одинаковую логику, и теперь все ебутся и переписывают половину приложения. А могли бы по-быстрому написать новые контроллеры и вызывать из них сервисы.
>>3284690 >Надо будет - вынесу в сервис 1-2 (хватает и одного раза) таких "надо" - и в следующий раз сразу делаешь как надо и плевать что "больше работы".
>>3284690 >Если делать сервис, придется уже не IFormFile а стрим по нормальному передавать, ведь сервис не должен же про HTTP знать и всю хуйню. Лол, так ты итак его на пике в стрим перегоняешь. >тогда и EF надо выпиливать, ведь слой приложения не должен знать про инфраструктуру Ну да. Выпиливашь в отдельный DAL слой и забываешь о нем. Просто передаешь/забираешь туда/оттуда нужные данные, без всякого знания о контексте, бд и вообще о том, что там под капотом.
Смыслов выносить всю шелуху из контроллеров несколько. Во первых - в проме, у тебя контроллеры будут выглядеть далеко не так, там еще до входа в метод у тебя может быть строк на 10...20 всяких атрибутов, предусловий, фильтров, пермишенов, доков и т.д. накидано быть. Т.е. и без непосредственно самого кода все будет засрано так, что некомфортно будет по этой портянке лазить Во вторых - у тебя, при таком подходе, в контроллерах будет пиздец как много кода, вплоть до идентичных методов строк на 50...10, у которых отличия будут в несколько команд. И когда нужно будет изменить, что-то в одном месте, то придется прокидывать все эти изменения руками во все другие места.
>так нехуй придумывать себе работу, которая нахуй никому кроме твоей шизы не сдалась. Да, тоже верно. Если ты в соло разрабатываешь или проект небольшой, то можно хоть дрочить в присядку - личное дело каждого.
>>3284706 Кто тебе прям мешает из контроллера - дернуть другой контроллер? Просто я проблемы не понимаю. Ты мало того что можешь так сделать, ты можешь сделать вот тот ваш контроллер - базовым классом, и сделать твои новые контроллеры - наследниками. Прям реальных причин делать сервисы - нет же.
>>3284714 Я вот так же думал последние 5 лет, и что заметил, ни разу прям НАДО не возникло. А когда возникало, то там с оговорками, что логика не одна и та же, а таки отличается, и если ты ее таки сведешь к одному - потом ты больше ебаться будешь от того, что ну, на деле - она только внешне была одинаковой.
>>3284715 >Лол, так ты итак его на пике в стрим перегоняешь Ну, ды. Но тут придется модельку какую-то еще одну уже для сервиса. Либо два аргумента, что харам.
> Смыслов выносить всю шелуху из контроллеров несколько. Та теорию-то я знаю. Просто вот сколько пишу так, все смотрят на меня как на ебаната. Меня если честно это уже подзалюбило. А последний год - я просто хочу прийти, сделать быстро таску и прикинуться ветошью на оставшееся время задачи.
>>3284729 >ни разу прям НАДО не возникло ну, глядя на твой код - охотно верю. у меня бы от одного вида портянки глаз дергался и я не мог бы спать нормально. А уж оптимальность этой портянки... ...помещение всего файла полностью в память MemoryStream (причем без учета реаллокаций ...и тут же дополнительная материализация его в array для подсчета хеша. ведь подсчет хеша на лету прямо из стрима это для слабаков ... имя папки "static" зашито. Ведь все знают что это всегда будет константой ... и снова дополнительное копирование ms.ToArray() при записи файла. Ну а зачем еще нужен GC как не работать лишний раз ... тэги проверяем на существование по одному. А почему бы и нет. База все равно ничем не занята ... и в базу запишем _saveFilesDirectory. Еще же одна константа) да и места что ли жалко ...обработка ошибок...ну ладно будем думать что просто не написал еще. Ведь портянка должна быть на 10к строк иначе челенджа не будет.
>>3284774 >помещение всего файла полностью в память MemoryStream > ...и тут же дополнительная материализация его в array для подсчета хеша. ведь подсчет хеша на лету прямо из стрима это для слабаков Потому что надо делать Position = 0, а я - не хочу.
> ... имя папки "static" зашито. Ведь все знают что это всегда будет константой Да
> ... и снова дополнительное копирование ms.ToArray() при записи файла. Ну а зачем еще нужен GC как не работать лишний раз А чо б и нет? Эт не хайлоад какой-то, а фановый проект на вечерок на выходные в меньше 500 строчек, основной целью которого было вспомнить как там на Vue писать-то, а то последний год - я на ебаной авалонии ебусь как скотина. Заебала авалония.
> тэги проверяем на существование по одному. А почему бы и нет. База все равно ничем не занята Именно.
> и в базу запишем _saveFilesDirectory. Еще же одна константа) Вообще не понял вот тут в чем причина доеба. Да, константа.
> ...обработка ошибок...ну ладно будем думать что просто не написал еще. Ведь портянка должна быть на 10к строк иначе челенджа не будет. Обработка ошибок - для слабых. В любом коде должна быть перчинка и щепотка неожиданности, иначе какой смысл.
>>3284804 >а я - не хочу. ведь каждый раз бог убивает котёнка. А только сволочь не будет думать о котятах.
>А чо б и нет? Эт не хайлоад какой-то, а фановый проект на вечерок ну наберешься опыта и поймешь. Потому что обычно сложно (и почти невозможно) заставить себя написать "намеренно плохо" если есть отличное решение на том же уровне сложности.
>не понял вот тут в чем причина доеба. Да, констант даже если она никогда не изменится - она бессмысленно занимает место в базе данных.
>Обработка ошибок - для слабых и то верно. ведь всё будет работать идеально. ведь идеальный код всегда работает идеально )
>>3284811 > ну наберешься опыта и поймешь. Потому что обычно сложно (и почти невозможно) заставить себя написать "намеренно плохо" если есть отличное решение на том же уровне сложности. В этом коде - нет ничего плохого. А портянки тоже надо уметь писать.
> даже если она никогда не изменится - она бессмысленно занимает место в базе данных Зато упрощает работу со ссылками уже на стороне клиента.
>>3284822 > А портянки тоже надо уметь писать. не могу придумать ни одного случая когда бы это умение пересилило бы "написать нормально". Ну только если на спор "кто напишет портянку длиннее и пойдет на рекорд"
>Зато упрощает работу со ссылками уже на стороне клиента. мифическое упрощение. ну ок ок. не буду спорить.
>>3284729 >Кто тебе прям мешает из контроллера - дернуть другой контроллер? Я даже не представляю как далеко меня пошлют (если вообще нахуй не выпиздят) если я такое предложу.
>>3284949 Ой, блядь. Контроллер - обычный класс, ничем от других не отличающиеся. В чем для твоих и тебя - принципиальная разница, дергаете вы методы "сервиса" или "контроллера"
К тому же, ты сам сказал, что ваши и так наговнякали. Так что не вижу проблемы. Сами говно сделали, так что нечего вонять на способы хотя бы какой-то там DRY применить. А потом - уже тот контроллер, который все нужное делает - можно превратить в сервис.
Блин, видел бы ты код одних финов. Они там вообще, из сервисов-воркеров лупбеком полноценные HTTP-запросы слали, потому что таки да, вся логика в контроллере, как нормально контроллер создать они не допетрили, и в итоге - вот такой-то веселый код выходил, оч весело было разбираться.
>>3284960 а потом все переедет в minimal api.... И контроллер - не обычный класс и вызвать его правильно это "перенаправить вызов к нему" через механизм роутинга, а не тупо получить из сервисов и дернуть. Потому что его не предназначен быть жестко зафиксированным. И в любой момент может измениться и хз что таким вот вызывателям потом делать.
Сап, шарпач. Такой вопрос - есть ли вообще в интернете репозитории, базы данных , просто сайты с пользовательскими библиотеками, всякими приколюхами, надписанными на шарпе. Чтобы можно было качнуть dllку какого нибудь Leha85 и посмотреть что он там написал, для честных работяг.
>>3287594 так нет никакой разницы. никто на вас не накладывает ограничение "делай так и не иначе". Так что все зависит от того что ты делаешь. Если у тебя вебсайт, то какой то урл для удаления с 100500 параметрами в querystring если одностраничник с бэкендом на асп - ну там может ты по рест правилам делаешь урлы, а может и нет. тут безсловно ажакс ибо иначе какой же это одностраничник. А может у тебя вообще поверх вебсокетов работает и не по хттп даже и там xml-rpc какой нить
асп, как и любой другой подобный фреймворк на любом языке, всего лишь дает возможность делать нужное тебе.
А по факту -потому что нельзя вызвать у инстанса статический метод таким образом. На то и существуют НЕ статические методы чтобы туда неявно проваливался this, и сущствуют СТАТИЧЕСКИЕ которые обязаны жить без этого this
>>3287644 А можно словами попроще? Из всего я понял только то, что метод не должен быть статическим, я убрал статик, оно заработало но пишет что я пидор и чтобы пофиксил метод и вернул статик назад. Кроме того у меня не получается референснуть имя в методе, срет ошибками про this. Сложна, нихуя нипанятна.
>>3287654 статический метод не принадлежит экземпляру, а принадлежит классу. И поэтому вызываться должен по имени класса. Изнутри класса можно и напрямую вызывать - не будешь же ты там имя класса использовать будучи...в этом классе.
И обычно оно пишет что ты не пидор, а что мол "смотри человек, у тебя в этом методе не используется this. Может лучше сделать его статическим и пусть народ пользуется им без необходимости создавать инстанс, без смс и регистрации"
>>3287665 Благодарю, помогло. Судя по всему в новой версии языка this не нужно использовать, оно само подтягивается. Вот глянь пожалуйста, здесь все выглядит красиво? Вроде работает без ошибок.
>>3287679 кроме тебя никто и не поймет что конструктору надо с такими именами параметров Да и не должен класс ничего знать про консоль. Дело класса держать данные и что то с ними делать. А куда выводится - не его дело. Сегодня ты в консоль выводишь - а завтра уже стринги носишь. не делай так.
>>3287685 А как красиво выводить в сосноль объекты? Мы всей кафедрой в питоне объект целиком в строку выводим и он красиво и автоматически форматируется. А в сишарпе как?
>>3287692 Да как хочешь. Просто не этим классом же. Сегодня у тебя консоль, завтра этот класс в формсах где ты сделаешь свой PrintMaterial и них не произойдет.
в питоне есть __repr__ и __str__ которые и использует принт для вывода в консоли, а не сам занимается форматированием.
в шарпах нет аналога __repr__, да и вообще подход с магическими методами уникален
Это снова я. Добавил еще пару классов и вылезли проблемы. Мне нужно создать инстанс класса, в котором мне нужно использовать пропертиз из другого класса. Например на пикче у меня есть класс с нодами и класс с членами. В классе членов есть свойство Длина и чтобы ее посчитиать мне нужно вытянуть из списка нодов координаты векторов. Но они недоступны, пишет что список nodes[] не существует в этом контексте. Как решаются такие проблемы в ООП?
(Да, я знаю что принт я пока не убрал, но уберу после первых дебагов)
В некоторых учебных материалах вижу настройку модели в OnModelCreating и нейронка тоже настраивает каждый раз. Поясните нахуя, если это всё автоматически делается. Если что-то нужно уточнить легче же с помощью атрибутов это сделать.
>>3288939 Ну смотри. Ты хочешь разделить бизнес-логику и логику БД, и создаешь отдельную библиотеку только с сущностями. Это библиотека нихрена не знает про EF/Dapper/Nhibernate - все что там есть это сущности (UserEntity) и интерфейсы (IEntity<T>).
>>3288963 Ну по сути, если я не планирую ничего разделять, то можно и обойтись без настройки? И если у меня куча сущностей с кучей свойств, это же ебануться можно, не?
>>3288975 >это же ебануться можно, не? Ебанешься ты когда EF на автомате законфигурирует тебе что-нибудь не так как ты ожидаешь и ты будешь ломать мозг в отладке - почему же оно не работает.
Бля, есть еще обучающие уроки но чтобы там чел был такой старый дядька в очках с усами? Такие почти всегда дохуя знают, я например впервые вообще вижу некоторые методы которые он использовал С такими дядьками обычно даже не задаешься вопросами "а нахуя это" или "зачем так усложнять" Надо так НАДО
>>3289460 Тем что по ощущениям - деградация в плане как спеца. Типа да, весело некоторую хуйню про многопоток вспомнить, но в целом, в плане архитектуры и забористости - десктоп, сильно проще чем среднестатистический бекенд, потому что, ну, если не совсем ебланы, у вас быстро паттерны вырабатываются, и вы просто ебашите и по какому-нибудь MVVM/MVC. Плюс, те проблемы что с бекендом случаются - на десктопе оч легко решаются, никаких тебе - ой, у нас что-то пошло не так, как пользователю дать знать об этом, ой, у нас надо локализацию сделать, кто и как должен делать, ой, а какой протокол придумать чтобы ебучию паггинацию, с группировкой, и вот этим всем сделать, ой, а как клиент, если надо - только то что ему нужно подгрузит... ну, короче, вся та фигня, которая случается из-за того что у тебя есть бек, есть фронт, и они отдельные приложения.
Сверху, половина времени возюканья с авалонией - это прочитать доки, понять, что доки устарели или откровенно пиздят - полезть смотреть исходники, т.к. опыт научил, что в авалонии -просто загуглить не получится, и сразу надо смотреть исходники. Но, типа скажем, в отличии от замарина, с которым лет 8 назад работал, сама по себе авалония - отторжения не вызывает. Есть косяки, но с ними жить можно, и воркэраунды тоже есть. Плюс, у авалонии - не совсем вахтеры сидят, так что ПРы принимают.
> автоматически Делается автоматически, но всегда есть апи, где ты можешь сделать свои уточнения.
При перегенерации кода, у тебя свойства не должны быть перетёрты. Но, партийные свойства вроде как завезут в следующем дотнете. Поэтому по классике конфигурируем билдерами
Я бы с ноги бил в ебальник за комментарии вида // Это стул, на нём сидят
Работать в целом будет, но такой подход несколько унылый, потому что ты обязан следить за тем, что потребители не вызвали код, который не проверяют this на готовность.
У тебя может возникнуть соблазн использовать https://www.castleproject.org/projects/dynamicproxy/ , чтобы при вызове твоего сервиса автоматически проверялась инициализация, но ни в коем случае не делай этого. Динамические прокси - это вообще самое конченое решение, и их используют в крайнем случае.
>>3289824 Причем тут юнити когда мы про вижлу? Я боюсь ща опять что-то ограничат и пососу бибу с шарпами из-за вижлы или там нугета. Да, можно впн и прочее, но кому это надо.
>>3289825 Тебе говорят, что ты можешь хоть в VS CODE разрабатывать. Ограничивать никто ничего не будет. Да и уже нечего ограничивать. Дотнет полностью открытый
>>3289827 Ну смотри у меня, приду и насру вам в тред.
На самом деле уже определился с шарпами. Да, в го проще вкатываться, но в долгосрочной перспективе после быстрого вката наступает эпоха тотального бойлерплейта, я уже стал понимать что избалован и быстро выгораю на примитивном синтаксисе, блин, я банально уже не могу без эксепшенов.
>>3289815 Это просто факт. Хз чем там занимается EF (может майнит), но стартовое время ужасное. Для асп.нет проектов поплевать (один раз запускаем, хотя я хз как они там отладку делают), а десктоп должен стартовать быстро.
> Плюс, те проблемы что с бекендом случаются - на десктопе оч легко решаются На десктопе хватает своих приколдесов. Порой базовую вещь приходится велосипедить, потому что из коробки её нет.
> доки устарели или откровенно пиздят Документация там полный пиздец, да. Около пустые страницы.
Щупаю авалонию и с одной стороны вроде прикольно, но и своих болячек хватает. Может сталкивался, как правильно вызывать Shutdown из App до первого отображения окна? Например, в сценарии, когда обязательную службу/зависимость не удалось проинициализировать.
>>3289827 > Дотнет полностью открытый Так пришли ссылку на исходники дебаггера. Его даже в dotnet SDK нет, только в виде проприетарного плагина для VS/VSCode. Есть только сторонний он самсунга, хз, какие у него подводные.
Существует ли удаленка на дотнете для джуна? Наткнулся на вот этот пдфник https://pdfupload(точка)io/docs/530c3aa5 , на 3 странице приблизительно моя ситуация - вкатился в гос парашу фулстеком крудошлепом+десктоп, но по совместительству приходиться заниматься хуитой вроде админства и эникейства и еще другой левой хуйней (специфика конкретной госсухи). Понимаю что у меня поверхностные знания и я особо не расту как специалист. В моем регионе (даже с перекатом) вакансий 1-2 десятка. Есть ли в треде успешные аноны которые с госухи/легаси/нуля вкатились во фриланс?
>>3289960 >Существует ли удаленка на дотнете для джуна? Да. Просто пробуйся сразу на вакансии мидлов. Если ты упорный, не тупой, покажешь желание развиваться и произведешь хорошее впечатление, то вполне можешь залететь (шансы даже больше чем просто на джуновский собес попасть). З.п. первое время будет ниже.
>>3289835 Ну так всегда ведь. Вот у медиатра тоже в начале на маленьких запросах время занимает много, но в долгосрочном плане он выигрывает у аналогов.
>>3290006 То есть можно и на мидла попытаться отликнуться? Просто я еще студент на последнем курсе, и меня даже не принимают на джуна. Может быть из-за неправильного резюме, либо им нужен именно человек полный рабочий день. мимо
>>3290102 Нет не всегда. Это особенность исключительно EF вон по ссылке "A large model typically means 100s to 1000s of entity types and relationships."
>>3290135 Что в твоем понимании 17я? как бы последняя она 17я.
>>3289855 молча сдохнут и пусть юзер гадает? делай лоадер скрин - там и прогресс инициализации можно показать и ошибку.
>>3290292 >ну есть же VS Code И чем он мне поможет? Я тут просто немного некрофилией занимаюсь, нужно старый проект под мобилу скомпилить, а в 22 чет нельзя теперь
>>3290279 мимо, другой чел, имею некро ноут для чтения в инете.
Обновился до 11 винды, пришлось идти за ssd ибо это хрень на старых жестких практически не работает, загрузка 6 минут на пустой винде, отклик на каждый клик вечный. Это ппц деградация. Зато могу теперь подолбиться в последнии шарпы, лежа под пледиком.
Как же у меня бомбит от мудаков, которые впихивают медиатор ЗА МЕСТО КОНТЕЙНЕРА, обмазывают всё десятком бехавиоров, а потом жалуются, что тормозит и никто нихуя не понятно, что происходит.
Кто-нибудь пробовал микросервисы собрать обратно в монолит? Как на шарпе это сделать с меньшей кровью? Пока что я придумал вот что: Сервис запускатор, который переопределит всем сервисам настройки запуска и будет такой-то входной точкой. А в дальнейшем - вынести то что в контроллерах было в MinimalAPI и подключать как подмодули к этому основному сервису. Как вам идея?
>>3290337 >Обновился до 11 винды Ты бы еще кувалдой по ноуту долбанул, а потом бы такой "гм, а чего это оно плохо работать стало".
У меня не ноут и вообще i9 - и то я обновляться не буду на это говно. Ну а любители говна ....ну хотя бы win 11 IoT ставьте что ле. (впрочем в любом случае IoT ибо приятный билд)
>>3290670 >Ставь линупс Зачем МНЕ это делать? А вообще шарпы там нормально поживают. Там плохо поживает мой основной хлебушек - WPF, а на авалонию не хочу из-за шрифтов.
>>3291802 С чего ты взял, что мы вообще выбирали между жабой и шарпом? У большинства при вкате даже мысли не возникало, что существует какая-то там жаба, похожая на шарп, и надо её рассматривать в качестве варианта. Я вот выбирал между шарпом и плюсами.
>>3291802 жава многословное говно, где десятилетиями внедряются фичи сначала "это не нужно никому", а потом все равно внедряются. Из-за этого в жаве даже родился проект ломбок - настолько там все медленно развивается. А в жаве гетсет наверное не сделают никогда, хотя это ж элементарнейшая фича.
>>3291802 У меня сперва была задача, а потом выбор языка. Для меня дилеммы выбора языка никогда не стоял. Делал плагины для различных графических редакторов, а там либо vb, либо C#. Поэтому я шел по такому пути vba -> VB.net -> C#. Это сейчас стандартом становится питон.
Но даже в качестве альтернативы шарпу я выберу кресты. Вопрос о джаве никогда не стоял. Но для меня программирование — побочное занятие, так-то я 3д-графикой занимаюсь, но даже здесь у меня никогда не стоял вопрос между условными майей, гудини или блендером. У всего одна и та же БАЗА, поэтому зная одно, можно в течении месяца перекатиться на другое. Даже зная C# очень просто изучить Houdini: ты и VEX сразу знаешь, и большую часть функционала нод.
И вообще, я руководствуюсь одним принципом, если я не знаю что выбрать, то я нахожусь не на той стадии, чтобы выбирать, потому что в реальности выбора, обычно, нет вовсе. Просто берешь и учишь что-то одно, но основательно. И не распыляйся.
>>3291802 Гейм дев (годот тоже он есть), норм виндовой десктоп, постоянно техническое развитие языка, не только синтаксиса.
Если ты выберешь джаву или го, у тебя будет только однообразный веб с туева кучей фреймворков, которые делают одно и тоже, но чуть по другому, а шарп почти язык общего назначения, как минимум даже не для работы, а для себя норм.
>>3292512 Ты попал в геймдев? Меня это больше всего привлекает в сишарп, то есть возможно с юнити работать. Но мне говорят, что это гиблое дело, то бишь вакансий мало и туда сложнее всего попасть.
>>3291802 Ну там юнитю, игори, стильно модно молодежно, да и сахара заебок, на самом деле после питона (первого языка) я чёт кайфанул с Шарпа, так и сижу на нём. Мимо нубасик
>>3291802 Выбираешь не язык, а набор технологий, язык дело вторичное.
И сравнивать надо не java и c#, а среду, в которой ты будешь работать.
Например:
В дотнете унифицированный nuget, который работает как часы В Java - Maven, Gradle, и прочая хуета, которая то сама ломается, то сама же потом чинится,
В Java оверпереуслождённый spring и зубодробительные фреймворки Всея Руси, котрые как-то взаимнопроникают друг в дружку и создают ёбнутые хитросплетения, которые КАК-ТО работают. В дотнете - aspnetcore, который простой как палка
Реализаций Java чрезмерно дохуя, всякие там openjdk, oracle, гугловская java в андроиде, и всё оно как-то полусовместимо между собой, как настроишь, так работать и будет. Рекомендуемая реализация Dotnet на текущий момент по факту одна (dotnet). Ты всегда знаешь, какой дотнет тебе использовать, тебе всегда рекомендуют современные практики
В джаве как-то уныло всё со структурами и дженериками. Как писать код, который работает "на стеке" - непонятно. Джававские коллекции и стримы - тоже вещь в себе. Странная хуйня с исключениями, которыми по оригинальной задумке никто не пользуется. Дотнет проектировали как копию джавы, поэтому там учли и исключения, и IEnumerable проще, и структуры, дженерики выглядят здоровее.
Джава как язык настолько не устраивает разработчиков, что богомерзкие джет-брейнс пытаются изобрести свои котлины и прочее. C# всех вроде устраивает, попытки переизобрести языки внутри платформы (f#) заканчиваются тем, что все модные фичи переносят в c#
>>3293471 а там не бывает профи. это ж авалония. постоянно приходится "да еп как в этой авалонии делается то, что в впф делается этак"
и начинаешь гуглить. а там основная справка это мегачат в котором дай бог гугл что то найдет.
Можно еще ИИ поспрашивать. Но вот gemma спросил мол что в авалонии заменяет CollectionView - а она говорит "юзай DataGridCollectionView люк". Правда в нем нет ни сортировки ни фильтрации. И толку тогда от такого. Я вот в далекие времена нагуглил DataGridCollectionView, который, несмотря на название, можно и для списков юзать, хотя и ИИ говорит что это никак нельзя и давай "закатывай солнце вручную" (хотя может уже и нельзя. я 100 лет назад щупал авалонию)
>>3293199 >язык дело вторичное. Не скажи, от фичастости шарпа ты балдеешь, а в топорной жабе ты долбишься об код. Так же после котлина на жабе больно. Я уже молчу про го.
>>3293567 И имей востребованные знания, с которыми легко можно найти работу. К тому же у реакта в десятки раз (а скорее всего сотни) больше сообщество, а значит куда легче найти ответы на вопросы, готовые контролы под твою задачу и тд. Да и в целом, как человек, который не так давно угорел по селфхостингу, хочу сказать, что десктоп нахуй не нужен. Веб приложения, которые можно запустить с любого устройства наше всё.
>>3293590 > и потом ее ненавидеть завидуя шарпистам что имеют дело "только с шарпом". С чего бы это? Наоборот разнообразие задач делает работу интереснее. Тем более приятно работать с технологией, которая популярна и для которой полно гайдов и лучших практик. А вот от ковыряния мертвых фреймворков только депрессия может начаться. > а для работы есть много других языков. выучи их несколько и шанс найти работу вырастет в миллион раз. Это какие другие языки помогут найти работу шарписту?
>>3293598 >разнообразие задач делает работу интереснее ну если тебе кодить на "шикарном" языке (настолько "шикарном" что в итоге родилось 100500 вариаций и трансляторов лишь бы не писать на нем) то рад за тебя. У других вот такой радости нет и они хотят видеть фронтенд - НИКОГДА и НИКОГДА+++
>ковыряния мертвых фреймворков это не делает фронтендовское говно привлекательным.
>Это какие другие языки помогут найти работу шарписту? Если цель всего - найти работу, то причем тут "шарпист". Не вижу в слове "жаваскрипт" частички "шарп". Я вот шарпит и я НЕ ЗНАЮ жаваскрипта (вернее конечно знаю ибо я полиглот, но руки мои этого говна не касаются)
А если брать языки в общем, то не только шарп приятен в "своей нише".
>>3293600 ну лично я не был бы против если бы многие фичи из котлина перешли в шарп. А то "вон у них есть значит у нас не будет" - говно, а не подход. В итоге вот выйдет дотнет 9. И что там реального полезного? Да ничего в общем то.
В шарпе увы хватает "нет искаропки и потому вот вам 100500 вариантов на выбор". где lateinit? потому что аттрибутов не хватает для его замены. Почему нельзя сделать расширение статического класса?
Банальное check/require то есть проверка предусловий. что в шарпе? Мертвый Contract (который это ж надо было так написать что он стал непортабельным. это ж УМЕТЬ НАДО) и 100000 вариантов Guard. В том числе от майков, где даже они умудрились забросить одну либу по этому поводу. и перенести в другую либу. А так каждый плодит свой велосипед. Потому что у команды создающей Visual Studio СВОЕ решение.
Заодно кину камень и в огород async примитивов. Та же херня. Ну что за идиотизм. что то меня понесло. остановлюсь пожалуй.
Есть такой код builder.Services.AddSingleton<ProxyStorage>(); // Add services to the container. var proxyStorage = builder.Services.BuildServiceProvider().GetService<ProxyStorage>();
Пишет мол что будет созданна копия сервиса. Вопрос состоит в том что вот у меня есть сервис ProxyStorage в конструкторе он заполняется данными, конструктор запускается при первом обращении к сервису. Мне нужно создать сервис(что бы сработал конструктор) до запуска приложения app.Run(); Как это сделать правильно?
>>3293647 >Как это сделать правильно? Правильно не делать так. Если твоему приложению нужны данные из него, то и находится он должен в контексте приложения, а не сбоку. Если не нужны, то и нечего его в контейнер запихивать строй отдельно.
>>3293653 Ну самому не нужны, сервис делает http запросы и получает прокси, которые потом будут выдавятся по api. Собственно заполнить сервис проксями надо сразу что бы при запросе api/GetProxy не ждать заполнения.
>>3293605 > ну если тебе кодить на "шикарном" языке (настолько "шикарном" что в итоге родилось 100500 вариаций и трансляторов лишь бы не писать на нем) то рад за тебя. Речь шла о фреймворке, а не языке. На реакте можно писать используя тайпскрипт, и последний как раз очень хороший язык, похожий на шарп. > это не делает фронтендовское говно привлекательным. Делает. Пользоваться популярными и активно развивающимися технологиями всегда приятно. > Если цель всего - найти работу, то причем тут "шарпист". Не вижу в слове "жаваскрипт" частички "шарп". Я вот шарпит и я НЕ ЗНАЮ жаваскрипта (вернее конечно знаю ибо я полиглот, но руки мои этого говна не касаются) При том, что это тред шарпа.
>>3293712 >На реакте можно писать используя тайпскрипт все равно это фронтенд. А значит привет HTML, CSS
>и активно развивающимися технологиями всегда приятно. это за какой? в мире жс их куча, рождаются и умирают. и даже в мире дотнет их минимум 3 - реакт, ангулар и вуе. Все 3 учить что ли? Мало ли что там на работе будет. (лучше учить - ни одной из них)
авалония так же весьма живая технология. И писать для десктопа на десктопной технологии банально удобнее чем веб в десктоп тащить. Тупо не нужно изучать ничего чужеродного.
>>3293723 > все равно это фронтенд. А значит привет HTML, CSS Лучшие языки для вёртстки так-то. Работать с ними одно удовольствие. > это за какой? в мире жс их куча, рождаются и умирают. и даже в мире дотнет их минимум 3 - реакт, ангулар и вуе. Все 3 учить что ли? Мало ли что там на работе будет. (лучше учить - ни одной из них) У тебя проблемы с памятью? Ну что ж, напомню - речь шла о реакте. > авалония так же весьма живая технология. И писать для десктопа на десктопной технологии банально удобнее чем веб в десктоп тащить. Тупо не нужно изучать ничего чужеродного. Нет, не удобнее, потому что у авалонии почти отсутствует документация, мало пользователей и почти нет сторонних библиотек контролов. Про чужеродность вообще не понятно, что имелось в виду.
>>3293754 >Лучшие языки для вёртстки так-то. Работать с ними одно удовольствие. А еще приятнее с ними не работать. Это тебе любой чистый бэкендер скажет )))
>У тебя проблемы с памятью? Ну что ж, напомню - речь шла о реакте. это ТЫ заявил о реакте. И не "учи реакт - будешь рад", а про работу заявил. Я же просто посмотрел "а что в мире дотнет является 'стандартным' фреймворком". Если с бэкендом понятно (там один asp.net), что с фронтендами? а там...пик
>мало пользователей потребителей? ну это уже каждому свое. Я вот на WPF пишу и не голодаю. Хотя весь мир скажет что "работы нет". >нет сторонних библиотек контролов во-первых, это чушь. Во-вторых - не особо и нужно.
>Про чужеродность вообще не понятно всё, что не шарп - то не шарп. тайпскрипт - он хоть не жаваскрипт, но и не шарп. то есть БУКВАЛЬНО ДРУГОЙ ЯЗЫК со своими правилами.
>>3293518 По началу так кажется, а потом начинает ощущаться вся его кривость, как будто его хорошо продумали, а остальное сделали второпях.
Лесенка лямбд нечитабельна. Если по названию метода ты можешь понять, что происходит и дропнуть погружение, то в лесенку лямб ты обязан погрузиться полностью, всегда.
Был проект котлин -> дотнет, один раз умирал, потом вроде возрадил кто-то (можно нагуглить переписку), какой там статус сейчас хз. Видимо никому это не надо, хотя это круче чем котлин -> жс.
>>3293613 Синтаксис вообще мало интересует, а вот технологии да. Я бы хотел зеленые потоки, корутины с диспетчером, которые не красят функции. Это чуть медленнее чем асинк/авей, зато потребность в го для меня исчезнет полностью.
>>3293801 >как будто его хорошо продумали, а остальное сделали второпях. когда наступит этот момент? а то из всего пока только "гы гы не сделали NTuple, ну и исключения в корутинах" Еще я срал на конструкторы, но оказалось в принципе удобно. - а потом и в шарпе такие сделали
>Лесенка лямбд нечитабельна дело привычки. Если у тебя такой метод, что сложно его читать - так может метод делает слишком много и нужно его разбить. Вот jetpack compose - наглядный пример сего действа. котлин вообще использует активный упор на "сидим на всех стульях и вот вам еще dsl сверху если хотите". Шарп же просто "очень сладкая жава, но со структурами"
>>3293805 Кому что. Если для выражения чего то нужно целый огород городить, то нахрен такое нужно. Жава и котлин тому пример. Не динозавры активно валят на котлин. как бы если тебе важно это, а не фичи языка - ну так и сиди на го. чего не сидится то? значит все же не только рантайм важен.
>>3293801 я бы сказал не "сложно скоупы читать", а мыслить многопоточно скоупами. Реально в стиле асинк/авейт + токен отмены сильно проще писать чем "скоупы плюс их отмена"
исключение это flow, но реактивность уже совсем из другой оперы
>>3293818 >когда наступит этот момент Я уже все и не вспомню. -Но у меня при обновление отвалилось приложение, начало дефолтное расширение подключать и потом ругать что сигнатура не подходит (зачем вообще оно дергается). Вроде с run() Хотя методы в приоритете. Как раз тогда узнал что там. -Была хрень с арифметикой при переносе строк, но потом видел пофиксилил. -Была хрень с символом $, там чтобы вставить в строку надо было такую хрень написать. Говорили что это норма, но потом пофиксили. -Вместо статик - хренотень, не помню название. -Победили цикл for(;;) дали ренжи, в итоге я там не мог написать аналог циклу фор, пришлось выдарчить while. Модно, молодежно. -Было нельзя сделать, вроде, приватный сеттер и публичный геттер. Говорили ненужно и вы тупые, а потом оказалось есть кейсы, но они все равно молодцы. -жвм не оптимизируют корутины, тормоза до 10 раз -сами корутины корявые, какая-то хрень с обраткой ошибок там у них была, не помню -чел кидал, что 25% производительности уходит на проверку наллов, там миллионы вызовов, это жесть. А так как нет своей jvm, пофиксить нельзя jit -дата классы без наследования, смысл их вообще, хрен домен размажешь красиво, бегаешь с какими-то клонами структур, который схожи между собой. -Компиляция, это ппц.
В общем, еще что-то было, конкретно по синтаксису, но я не помню. Мне хватает анальной привязки к IDE, которую уже не получить и вообще я люблю vscode
>>3293952 круто конечно что ты постарался вспомнить, но твои придирки либо к багам, либо к раннему синтаксису, либо к "не так как я привык" либо к "гребаный жава мир"
>Вместо статик - хренотень, не помню название. говорил я, а теперь говорю что хренотень в шарпе. В котлине статик это полноценный объект. там просто синтаксис странный companion object пока не поймешь что это не мантра, а object это тот синглтоновский. Который позволяет интерфейсы, и расширения для статиков, и скоупы и "реализация интерфейса на месте". Обо всем этом в шарпе можно только мечтать. А почему? что мешает добавить хотя бы последнее? да и первое нормально сделать.и второе.и третье. Вещи то классные, и CLR преград не делает.
>какая-то хрень с обраткой ошибок там у них была это да. самая дикая тема что исключения не ловятся по обычному и там целая наука. но видимо была причина это сделать.
>на проверку наллов, там миллионы вызовов, это жесть да. вырезается прогуардом, но да - в релизе они есть если не вырезать их. опять же жава наследие и к синтаксису отношения не имеет.
>смысл их вообще ну как те же рекорды в шарпе. тот же смысл. в шарпе наследование рекордов тоже хрень.
а еще в котлине есть sealed, который помимо прочего позволяет сделать sicrimination union который в шарпе сколько лет народ просит сделать. Одна из самых востребованных фич - в дотнет 9 ее по-прежнему не видать. про енуму шарповские вы и сами знаете.
а питоновский NewType? или же инлайн валуе классы из котлина? то есть используем zero-cost врапперы вместо примитивных типов. Ведь удобно иногда, но нет ничего подобного. И опять же CLR не мешает.
>дали ренжи, в итоге я там не мог написать аналог циклу фор, пришлось выдарчить whil сразу видно - чел не питонист ))) и не растовик. и не ....
твои придирки в основном правдивы, но это не проблемы "хочу сделать вот это и язык мне мешает выразить мысль и заставляет плодить монстра." А вот в шарпе если ты мыслишь не "это сладкая жава", то бывают огорчения и печаль что нет того или этого.
Я тоже так могу: Джава говно потому что в RabbitMQ удобные exchange. Джава говно потому что в ИКЕЕ быстрая доставка. Джава говно потому что у трёхлитрового BMW шесть цилиндров.
>>3294043 я за собой повторяю. Я просто говорю факт. Больные синдромом утенка не поймут. я пишу на нескольких языках. Шарп хорош, но выразительность - не самая сильная его сторона. Да, в нем много сладкого, но это просто "сладость или жава". Это не видно если ты сравниваешь его с жавой ибо шарп изначально вырос из "делаем свою жаву". Но это прекрасно видно когда смотришь на другие языки - а там фичи, которые вполне могли быть в шарпе, но их нет. И ты не понимаешь почему.
Возьмем простое. Методы расширения все помнят? они вышли для инстансов. Но если нам нужно добавить для статиков, то плоди свои классы SomeClassEx.SomeMethod. Спрашивается ПОЧЕМУ? ведь расширения по своей сути и есть статики ничего в CLR править не нужно.
А ConfigureAwait? эта длинная портянка где писателям либ нужно писать ConfigureAwait(false). И сколько просьб "ну сделайте флаг на уровне сборки чтобы не нужно было писать. ну блин есть же люди что пишут либы (и их дохера, посмотрите на нюгет), а не приложения"
и этот список можно продолжать, и это....только претензии к сахару шарпа. Это еще я не касался "а вот в других языках не нужно строить свой вавилон для таких случаев, а можно так сделать".
Увлеклись своими спанами, что нужные фичи не делают десятилетиями, а если делают, то не сильно продуманно.
И это я еще не касался собственно "а почему бы вот это не перетащить к нам". Конструкторы же перетащили (правда убого, но все же). а другие удачные фичи почему нет?
в котлине родился jetpack compose, потому что язык позволяет. А в шарпе так и не родился rocket, потому что язык позволяет на уровне swift combine/flutter что довольно убого по сравнению с хамл (при всех недостатках хамла, коих 100 тыщ миллионов)
> Есть такой код > builder.Services.AddSingleton<ProxyStorage>(); > // Add services to the container. > var proxyStorage = builder.Services.BuildServiceProvider().GetService<ProxyStorage>(); >>3293655 > var proxyStorage = new ProxyStorage(); > builder.Services.AddSingleton(proxyStorage); > Так?
Не видишь подвоха? Ты только не ругайся, но я просто предположу, что ты не понимаешь разницы между созданием инстанса и присваиванием данных переменной. Правильный код таков: > builder.Services.AddSingleton(new ProxyStorage()); //Мы создали инстанс и сразу скормили его билдеру, без создания лишних переменных. > // Если какой-то из компонентов нам нужно задействовать сейчас, мы вытаскиваем его в переменную, чисто для удобства работы: > var proxyStorage = builder.Services.BuildServiceProvider().GetService<ProxyStorage>();
>>3293818 >чел кидал, что 25% производительности уходит на проверку наллов, там миллионы вызовов, это жесть. А так как нет своей jvm, пофиксить нельзя jit >>3293978 >да. вырезается прогуардом, но да - в релизе они есть если не вырезать их. опять же жава наследие и к синтаксису отношения не имеет.
Вы о какой проверке? Типа при вызове инстанс методов и при обращении к полям методов объекта?
>>3294629 не нулл параметры дополнительно в рантайме проверяются на не нулльность. Компилятор услужливо прописывает их.
То же самое что в шарпе проставить везде что то типа Guard.NotNull в начале каждого метода для каждого не нулл параметра. Что, в общем то, не является чем то этаким.
>>3294642 >То же самое что в шарпе проставить везде что то типа Guard.NotNull в начале каждого метода для каждого не нулл параметра. >Что, в общем то, не является чем то этаким. ты про [NotNull] в методе?
>>3294648 угу, если компилятор компилит его в проверку я лишними проверками не пользуюсь. но похоже что да - компилит.
ну вот если для всех не нуллабле проставить этот аттрибут, то получишь что компилятор за тебя накомпилит в каждом методе проверку. и будет то же самое, что в котлин.
>>3293978 >же инлайн валуе классы из котлина Extension types довольно похожи, не? Вообще, Inline value classes похоже на костыль. >>3294366 >Увлеклись своими спанами, что нужные фичи не делают десятилетиями, а если делают, то не сильно продуманно. Ну у такой perf-oriented фигни, целевая аудитория меньше, так что они могут себе позволить здесь больше "свободы" (дотнету уже 22 года, и всё ещё можно видеть ответы уровня "ссылочные типы в куче, типы значения - на стеке", а ведь это на поверхности, в отличии от всяких scoped ref и т.д.).
Они ведь не просто хотят добавить фичу, а чтобы она была ещё и производительной. Поэтому они такого: >>3294642 , никогда не сделают.
>не нулл параметры дополнительно в рантайме проверяются на не нулльность А какое исключение выкидывается если не-налл объект был налл?
>>3294677 >Extension types довольно похожи, не? не знаю. фича еще не вышла, выйдет - буду смотреть >Inline value classes похоже на костыль фича как фича. вот есть у тебя сигнатура метода void Foo(int a, int b, int c, ...) удачи не ошибаться так хоть компилятор помогает. конечно именование и вера помогают - но вот это и есть костыль.
>Они ведь не просто хотят добавить фичу нет. они просто упоротые все должно быть похоже на жаву, поэтому и делают тупо. ConfigureAwait тому пример. Можно было сделать бы await/await? и было бы шикарно, но нет - пишите портянки. Они просто занимаются херней.
>никогда не сделают да конечно. фича компилятора такая есть, просто они не могут включить такое по дефолту, ведь брикингченжес. Поэтому весь нуллчек он в компильтайме и на уровне варнингов. И производительность тут не причем.
>А какое исключение выкидывается если не-налл объект был налл? NRE конечно. то что в котлине нуллабилити искаропки не значит что ему не приходится работать с кодом, который про это ни дуду, то есть с жавой. Вот он и прописывает проверочки в рантайме. И шарп тоже был бы такой бы если бы нуллабилити был со старта, а не через 10000 лет.
>>3294665 >checkNotNullParameter Что этот метод там делает? Неужели он не простой, чтобы ещё и заинлайниться. Там остальной код делает 2+2? Было бы хорошо посмотреть что сгенерировал JIT, жаль в godbolt'е нельзя. Неужели там не как на пике (хотя код на пике производит довольно много кода, по сравнению с отсутствующей проверкой, но ведь такие проверки только в начале метода и после этого JIT может не генерить проверки этих объектов на null вообще). Короче - странно.
>>3294668 >Меньше 5% накладных расходов, хуйня Вроде мало, но 5% перфа уходит на хуй пойми что.
>3294692 >они просто упоротые все должно быть похоже на жаву Как там в 2002-ом? >ConfigureAwait >да конечно. фича компилятора такая есть, просто они не могут включить такое по дефолту, ведь брикингченжес. Поэтому весь нуллчек он в компильтайме и на уровне варнингов. Я где в на гитхабе у них читал в ответах, что одна из причин это то что C# должен быть один, никаких флагов которые могут "породить" новые диалекты и т.д. Ну и практически полное отсутствие breaking changes.
Как пример есть ещё одна проблема: ковариантность массивов ("Base[] array = new Derived[...];"). И вот при записи в этот "Base[] array" нужно проверять что у записываемого типа, Derived есть в предках. JIT иногда может убрать эти проверки. А ведь массивы есть в List<T> и т.д., и этот, хоть и относительно небольшой, оверхед они тянут до сих пор. Поэтому они не хотят высирать хуйню и потом тянуть её (хотя такое всё ещё у них бывает).
Ну и я например, недоволен почти-готовыми фичами. Или где они забили на те места где фичу нельзя использовать, хотя по логике можно было бы (забыл пример по-лучше, но вот в C# 13 наконец-то сделали "Enable ref locals and unsafe contexts in iterators and async methods"). Covariant returns добавили только спустя 18 лет (C# 9, .NET 5) и то криво: https://github.com/dotnet/runtime/issues/92047 >Methods were covariant return types applies does not inherit attributes
Как определить где у меня узкое место? Вот у меня в семафоре запускаются таски в низ создаются httpclientы и делаются запросы. При 1000 тасок падает интернет. Запущено при этом 400 по данным мониторы ресурсов. БольшАя часть соединений отлетает с ошибкой так как прокся хуевая. Дак вот в чем проблема? У меня win 10 В винде? Мб роутер не даёт много соединений открыть?
>>3294760 >Как там в 2002-ом? точно так же как и в 2024 - шарп очень беден на синтаксис что не "жавосишный" и вообще на разную синтаксическую магию
котлин - require/check в разных вариациях. все искаропки шарп - "у нас нет функций у нас лапки,а кейворды мы делать не будем ибо это не по жавишному"
и да да тот же ConfigureAwait. он МЕТОД потому что " у нас тут жава просто сладкая, а не ваши эти вот всякие там. ишь чего захотели. удобства они захотели. сосисе писос. нам говнокодеры которые рукожопы важнее будут чем всякие там либописатели. Вот для них мы сделали ConfigureAwait тру по дефолту, а не явное указание, поняли вы кого мы любим"
>Поэтому они не хотят высирать хуйню что не помешало им забыть сделать IReadOnlyList (очевиднейшая вещь), сразу нормальное разделение коллекций, нуллсафети (ведь у нас же тут "жавка только наша") и убогие енумы, всякие new (ну жава же), точки с запятой и так далее. но не помешало сделать Contract который невозможно перенести (это бля вообще как можно было так прибить гвоздями банальный Guard).
>>3294787 учи много языков. они покажут тебе разные парадигмы которые ты начнешь тащить в шарп, будешь материться и так будешь жить.
>>3294648 > [NotNull] Такие атрибуты не компилируются никуда, особенно, если это атрибуты от богомерзких JetBrains. Они только для кодоанализатора нужны
Поясни, как такое получается? Это какая-то магия от богомерзкого jetbrains пидоры поганые?
Дай догадаюсь, там генерируется код, что если объект null, то вбросить argumentNullException? Если да - то нахуя нужно, если это работает автоматически в среде исполнения?
>>3295046 Я хз, это не я копался. Им же надо гарантировать нулл-сейфети, вот и упоролись. По мне проверок во время компиляции хватило бы, разницы нет NPE это или KNPE.
Тут больше интересно другое, давно на конференциях они говорили, мол да у нас есть там просадки по проверкам, но мол пустяк, это же проверки просто. А оказалось не пустяк и вероятно знали об этом.
В общем, либо ты берешь и пишешь язык со своим жвм, либо постоянно мимикриуешь на чужой и страдаешь. Та же беда с асинками там, jit не может оптимизировать тот котлин код и тормоза хорошие.
Поэтому, кстати, я выбрал шарпы в свое время, потому что все равно можно встретить затупы и 100% интеропа быть не может (хотя котлин синтаксисом больше понравился).
И тоже говно тайпскрипт, вроде типы, круто, а близкое родство с жс приносит тебе все тоже его говно, а потом еще типы мешают прототипировать и ты как будто в двойне говна поел
В качестве недостатка Шарпа иногда пишут про уход микрософта из России. Типа чем это чревато вообще? В сущности какие возможные последствия, ограничения и блокировки?
>>3294795 Ну мы с тобой не договоримся. У тебя своё видение C#. у меня своё. Тебе хочется видеть больше сахара, а мне уже давно достаточно.
Мне не нравится новый сахарок (с 9-ой версии). С одной стороны - да, код стал короче, удобнее и т.д., с другой - новый синтаксис, который ещё выбивается из предыдущего синтаксиса C#. Например: все так хотели pattern matching, жить без него не могли, и чё это: "if (a is { Length: < 42 })"? Причем 42 нельзя заменить неконстантой. Единственное что я прямо юзаю из паттерн матчинга это "x is null"/"x is not null".
Тебе нравится require/check, а меня аж корёжит от такого.
>>3293978 >инлайн валуе классы из котлина? то есть используем zero-cost врапперы вместо примитивных типов. Ведь удобно иногда, но нет ничего подобного. Ещё, например, структура-враппер (я вкурсе про null и т.д.). Но ты хочешь новую фичу для этого.
Мне вот не нравиться, что люди тянут в C# fp-подобную хуйню. Как будто люди мыслят: "Мне похуй чё там было в языке раньше, я вот увидел X в языке Y, хочу в C# такое.", и похуй что в C# есть похожее (да можно сказать что похоже, но не такое, так давайте добавим 500 вариаций одной фигни, только разных цветов). Ещё хороший пример - Green Threads. Да, давайте выкинем async/await и добавим спорную фичу из языка в котором даже небыло чего-то похожего на async/await. "Я не пользуюсь даже структурами (т.е. довольно большой пласт языка я не знаю), но я точно знаю как сделать C# great again".
>>3295535 >Тебе хочется видеть больше сахара просто ты вообще не понимаешь ибо для тебя это "малопонятные рассуждения об абстрактном". Ты не щупал и не можешь оценить что да как
я не больше сахара хочу. я хочу НОРМАЛЬНУЮ реализацию сахара и фич ну и конечно полезные фичи
>синтаксис, который ещё выбивается из предыдущего синтаксиса C# ой. что я слышу - чел критикует реализацию фичи. мол сделана коряво. И эти люди еще меня критикуют лол.
>а меня аж корёжит от такого от какого? ты не юзаешь проверку предусловий? ну значит ты очень смелый программист. Мелкие вот себя такими не считают и проверки у них почти везде. не нравится синтаксис? то есть 100500 библиотек на тему тебе норм. ну ок ок.
>структура-враппер структура не является эквивалентом ибо обладает "особенностями" с которыми не каждый любит разбираться. Не ступать на грабли со структурами - особое умение, которым обладает 3.5 человека.
>Мне вот не нравиться, что люди тянут в C# fp-подобную хуйню. тебе какая разница - не используй. а вот людям не нравится когда компилятор НЕ МОЖЕТ проверить что ты там не забыл в свитче где нибудь проверить ВСЕ варианты того же енума. И нет никакой возможности управлять этим.
Я понял что ты не любитель строгости контрактов. Вот я бы предпочел иметь val (а не только var), чтобы не "мамой клянусь себе что не присвою ей ничего нигде", а компилятор помогал. Так же я люблю принимать в методы IReadOnlyList если не собираюсь ничего в нем менять (а народ же везде таскает IList и вам похер). Туда же и говнодизайн коллекций где сразу не создали "вот вам фрозен, а вот вам мутабельные коллекции" Ну и конечно концепция fail-fast, то есть при нарушении предусловия инварианта и так далее - сдохни сразу, а не через 100 уровней наглухо потеряв контекст первоначальной проблемы.
Ну и фп - ты не используешь LINQ? форы пишешь да? ну ты зверь. фп типа Discrimination Union решает проблему неявности исключений и их "перфоманса". У тебя есть другое решение? Ах нету? ну ясно ясно.
>давайте выкинем async/await зачем. фича нормальная. народ не просит ее выбрасывать. А просит лишь "а можно не писать портянку?"
>спорную фичу из языка в котором даже небыло чего-то похожего на async/await Это какую такую фичу? Расширение статических классов чтобы не пришлось писать ClassEx.NewMethod()? Или автореализацию когда кто то принимает интерфейс и тебе не хочется заводить отдельный именованный класс для ЕДИНСТВЕННОГО раза, да еще получить замыкание. Чет лябмды тебя не смущают, а ведь это то же самое, только там метод один. Или возможность делать обертки с делегированием где ты переопределил только нужное и не вынужден писать остальные 100500 методов которые не делают ничего кроме прокидывания (ну ладно тут в принципе можно нагенерить) или делегацию свойств когда ....ну это ты все равно не поймешь
хз причем тут асинк
Я вот щас пишу LINQ и мне нужен метод который не будет делать ничего с коллекцией - и где такой искаропки? в либах его обычно называют OnEach или Tap. Ну а какой искаропки? Select...где я делаю нужное и возвращаю без изменений? Вот это уродство.
ты правильно заметил - мы не договоримся ибо ты даже не понимаешь о чем я
>>3295570 > Я вот щас пишу LINQ и мне нужен метод который не будет делать ничего с коллекцией - и где такой искаропки? в либах его обычно называют OnEach или Tap. Ну а какой искаропки? Select...где я делаю нужное и возвращаю без изменений? Вот это уродство. Так есть метод foreach для ilist
>>3295570 >от какого? ты не юзаешь проверку предусловий? ну значит ты очень смелый программист. Мелкие вот себя такими не считают и проверки у них почти везде. >не нравится синтаксис? то есть 100500 библиотек на тему тебе норм. ну ок ок. Как по-твоему должен выглядеть require из котлина в C#? Если точно так же (синтаксис), то это пиздец.
И я не говорил что я не проверяю предусловия. Я обмазываюсь стандартными статическими ThrowIf у ексепшенов, где они есть, остальное по старинке или кастомные методы, + Debug.Assert().
>структура не является эквивалентом ибо обладает "особенностями" с которыми не каждый любит разбираться. Не ступать на грабли со структурами - особое умение, которым обладает 3.5 человека. Ну так потому что "не каждый любит разбираться". Я вкурсе, что есть грабли, но практически все это решаеться, если сделать структуру readonly (что разрабы дотнета и советуют).
>а вот людям не нравится когда компилятор НЕ МОЖЕТ проверить что ты там не забыл в свитче где нибудь проверить ВСЕ варианты того же енума. И нет никакой возможности управлять этим. А анализаторы?
>Вот я бы предпочел иметь val По мне это фича с сомнительной ценностью.
>IReadOnlyList >Туда же и говнодизайн коллекций где сразу не создали "вот вам фрозен, а вот вам мутабельные коллекции" Не спорю, это проёбы.
>Ну и фп - ты не используешь LINQ? форы пишешь да? ну ты зверь. Я плохо выразился. Я имею ввиду сомнительные фичи (с сомнительной ценностью) и синтаксис (тот же requre из котлина).
>Discrimination Union Неплохая фича, но опять таки, новая "концепция" (не знаю/не помню более правильное слово) в языке.
>Это какую такую фичу? Я имел ввиду джавишные Green Threads.
>Я вот щас пишу LINQ и мне нужен метод который не будет делать ничего с коллекцией - и где такой искаропки? в либах его обычно называют OnEach или Tap. Ну а какой искаропки? Select...где я делаю нужное и возвращаю без изменений? Вот это уродство. Написать свой экстенш метод? Вкинуть issue в dotnet/runtime? Это такая большая проблема?
>ибо ты даже не понимаешь о чем я Я вроде понимаю, но мне кажется что мы смотрим на язык по разному и по разному представляем куда он должен развиваться.
Ну и по поводу новых фич в языке. Я не против нового, но только если оно даёт что-то кардинально новое (static abstract interface members), унифицирует/улучшает существующее (collection expressions) или то что нельзя было сделать раньше вообще или делалось с огромными костылями (allows ref struct).
>говнодизайн Вот начали они делать .NET Core, и вроде всё говно выкинули, а потом разрабы заныли и они вернули всю BCL взад, хотя могли исправить те же IReadOnlyList, выкинуть не generic коллекции и т.д.
>>3294366 >Увлеклись своими спанами Я так понимаю, спаны тебе не нравятся и ты ими не пользуешься, да? C# это ведь не только базы данных и бэкенд.
А я вот не знал что мне нужны спаны, но я кайфанул от их добавления. Единый интерфейс для строк, массивов, неуправляемой памяти, это же круто. MemoryExtensions - дяди за тебя уже написали высокоотимизированные методы, плюс добавили методы которых нет ни у строк, ни у массивов. Те люди, кто писал perf зависимый код, получили кучу возможностей его оптимизировать (приложив немного усилий - спаны и методы их принимающие (хотя спаны != перформанс автоматом), приложив побольше усилий - hardware intrinsics). Причем спан (и всё связанное), в какой-то степени, основан на ref аргументах, т.е. на фиче которая уже была в языке.
>нужные фичи не делают десятилетиями Ну тут я хз что сказать. Кто-то одни фичи хочет, кто-то другие, и каждый считает их фичу наиболее важной. Одни жалуются, что много сахара, другим - мало. Кому-то релизы языка слишком частые. И т.д. Не помню как там, но "языки делятся на те, которые все ругают, и на которых никто не пишет".
Ну и я очень часто вижу (посты, видео, разговоры), где люди относятся к релизу новой версии C#, как: "Мою фичу не добавили - релиз говно" или "Известную мне фичу не добавили - релиз говно". Как будто люди даже не смотрят что там ещё добавили, не думают как они могут заюзать новые фичи.
>>3295757 >Ну и конечно концепция fail-fast, то есть при нарушении предусловия инварианта и так далее - сдохни сразу, а не через 100 уровней наглухо потеряв контекст первоначальной проблемы. Ну вот люди захотели красиво и безопасно, а потом "аааа, checkNotNullParameter тормозит приложение".
>>3295757 >Как по-твоему должен выглядеть require из котлина в C# да как угодно. Хоть Guard.бла бла. Но проблема не в синтаксисе, а в отсутствии стандартного решения. И да, require в котлине выглядят чудесно. Он ведь не шарп и там методы существуют и БЕЗ классов. и это шикарно. >остальное по старинке или кастомные методы, + Debug.Assert(). велосипеды велосипеды. и эти люди.... > сделать структуру readonly (что разрабы дотнета и советуют). понимаешь разницу между "рекомендуется" и "по другому не сможешь ибо компилятор не даст"? а она есть >А анализаторы? ты про эти костыли...которых и не существует ) >новая "концепция" этой новой концепции много десятилетий. И много лет просят ее сделать в шарпе. Она уже бородатая концепция которая набрала сторонников за это время. >джавишные Green Threads. я о них вообще не говорил. Я говорил за выразительность. >по разному представляем куда он должен развиваться. я НЕ ОТРИЦАЮ других идей если они нормальные. это ТЫ занимаешься "оно нинужно ибо мне не нра у меня синдром уточки младенца и не хочу никаких фич". (ты прямо каноничный жавист)
ну то есть ты согласился со мной. быстро же ты переобуваешься. ну или не понимаешь о чем говоришь. >а потом разрабы заныли вот такие как ты ))))
>>3295780 >Я так понимаю, спаны тебе не нравятся хз как можно было сделать такой вывод. Я просто сказал что они увлеклись ими и забыли про кучу хотелок в чемпионсах которые годами висят и пользы от них даже больше. >и каждый считает их фичу наиболее важной для этого и есть голосовалка. и хватит путать фичи и сахар - это АБСОЛЮТНО РАЗНЫЕ ВЕЩИ. >Мою фичу не добавили ох ты скачешь туда сюда. еще раз говорю я придираюсь к а) они не добавляют МНОГОЛЕТНИЕ ЧЕМПИОНСКИЕ ФИЧИ. то есть фичи что хотят МНОГО МНОГО ЛЮДЕЙ б) а когда если что то делают то делают через жопу по свойски
>checkNotNullParameter тормозит приложение" не думал что ....а хотя нет, вполне думал, что есть дохрена людей что не отличают проверки на нулл (которые можно доверить компилятору) от контрактов проверяющих все остальное (про которое компилятор конечно знать не может).
>>3295473 Шарпы с дотнетом попенсорс, если кто-то и начнет забирать попенсорс, то не будет уже ничего и нигде. Причем лицемеры молчат что дефолт jvm (не опенждк), которую ты ставишь обычно - пропритарна и под анальной лицензией. Вот и думай.
>>3295855 > Шарпы с дотнетом попенсорс Ссылку на исходники дебаггера когда-нибудь пришлёшь? > которую ты ставишь обычно Я понял, это ad nauseam. Можно продолжать постить до бесконечности этот пук про "дефолт jvm", игнорируя любые ответы, и перемога точно наступит.
>>3295535 >Green Threads Никак для тебя ничего не изменят и они не мешают концепции асинков, это две разные техи которые не пересекаются (но, вероятно, можно будет сломать вместе). Причем гринтреды медленнее, такова цена за них и диспетчер, а блокирующие i/o вообще шедулится тупо в системный поток, как-то проблему с дробилками надо решать (в го тупо на 60 итерацию делают переключение, а раньше зависал). В общем, свои минусы и плюсы, так что выбор был бы интересный - шарпы только выиграли с этого (го просто будет "ненужон").
Я вот кстати хз как там котлин с гринтредами дружит и какие они в жабе получились, но меня уже манит эта связка, мне очень давно нужен "го с нормальным синтаксисом". Но это мне нужен и таких как я хз сколько.
>>3295863 > "го с нормальным синтаксисом". Но это мне нужен и таких как я хз сколько. ну это если памяти не жалко. иначе размен не очень.
А го и так не нужон - его писали в гугле для своих и он, как и гит по той же причине, получился уродливым. Смотришь и диву даешься. даже в расте синтаксис лучше.
>>3295861 >Ссылку на исходники дебаггера когда-нибудь пришлёшь? Может еще сорцы винды? Он бесплатный, что тебе нехватает? Вот vscode распространяется по проприетарной лицензии и имеет открытые сорцы, но что-то из сорцев его никто не собирает (как и твою проприетарную жвм все качают с оффсайта, а опенждк невсрались).
Кстати, дебагер от житбрейсов разве можно отодрать от ide? У жабы нет же вообще дебаггера. Так что это опенсорс, возьми и напиши свой. Если не написано, значит не нужно.
>>3295883 >ну это если памяти не жалко. иначе размен не очень. Какой памяти? Го не резервирует память как в шарпожабах про запас или быстро отдает ее системе, но жрет почти так же под нагрузкой. Так что еще сомнительно, пожертвовать 50мб озу или долбится постоянно в системные вызовы туда сюда. Да и вопрос поколений в гц, в го реализовали это или GC долбит всю память?
Красота раста кончается после кода уровня лаба1 и до первого рефакторинга с лайфтами и чудаковатым асинхроном. То как сделали обработку ошибок в расте в сравнение в зигом и нуллабл типы вместо древних опшинов, куда лучше. по сути обработка ошибо тот же if..else если не считать нового сахара с "вопросом"
>>3295904 > Он бесплатный, что тебе нехватает? Ой, а куда же делась "платформа с открытым исходным кодом" без проприетарного тулинга и анальной лицензии? > vscode распространяется по проприетарной лицензии Кому нужен опенсорс, тот пытается юзать vscodium, вот только проприетарный дебаггер от MS там работать не хочет. > жвм все качают с оффсайта, а опенждк невсрались Жвм с оффсайта никто не качает, все качают открытый бесплатный Temurin, и да, гоняют его в проде, а не для запуска пиратского майнкрафта. > дебагер от житбрейсов разве можно отодрать от ide Дебаггер для шарпа нельзя. Жабовского дебаггера там нет, используется опенсорсный из OpenJDK. > Больно, да, жабёнок? Но это реальность. Слив засчитан. Нечего тебе рот открывать, раз про жабу ты слышал только из постов на двачах.
P.S. сам ничего против шарпа не имею, замечательный язык, во многом превосходящий жабу. Всё портит проприетарный тулинг.
>>3295905 а причем тут го тебя ж тянет в жаву или даже котлин (если в нем можно виртуальные жава треды)
ну да. лайфтаймы раста это нужно въехать в них. но там хоть понять можно. А смотришь на го с его синтаксисом и думаешь "а нах... сделали так? чтобы просто отличаться от привычного того же в других языках? ну ок"
>по сути обработка ошибо тот же if..else да. но фпшно.
>>3295906 > Ой, а куда же делась "платформа с открытым исходным кодом" без проприетарного тулинга Сам придумал, сам повозмущался.
>проприетарный дебаггер от MS Фу, лучше правильный проприетарный дебаггер от джитбрейнс.
>Жвм с оффсайта никто не качает, 99% даже не знают что это анальная пропретарщина и ставят где удобнее. Если только пакетные менеджеры линукса тянут попенджк, но кто там проверяет вообще этот зоопарк.
>используется опенсорсный из OpenJDK. Что делает дебаггер в попенждк?
>Слив засчитан С победой тебя триумфатор!
>сам ничего против шарпа не имею, замечательный язык, во многом превосходящий жабу. Я рад что ты погрузился в шарпы, еще несколько месяцев назад ты такую ахинею нес, теперь хоть просветился и осознал (да я тебя узнал, ты серишь как под копирку.)
>>3295907 А ну да, джава жрет еще как. Озу не всегда проблема, микросервисы не пишу. Оказалось можно котлин корутины под зеленые потоки запускать, но что-то лень это все исследовать.
Я про это и говорю, что круто было бы если в шарпах завезли, потому как в мир жвм не хочется лезть. мозг не резиновый
>>3295906 Опыт показывает, что проприетарные дебаггеры от платных IDE куда лучше, опенсорсных огрызков работающих кое как для галочки. Я буквально недавно дергал какой-то раст и го дебаггер и обливался, ибо избалован идей и шарповской вижлой. Главное что в вскоде бесплатно есть, я хз в комьюнити версии брейнсов есть у джавы такая же щедрость?
>>3295907 >думаешь "а нах... сделали так? чтобы просто отличаться от привычного того же в других языках? ну ок" У них кстати целая статья есть на тему "почему мы вывод типа сделали после, а не перед идентификатором" и там все сводится к "мы считаем, что так удобнее"
>>3296335 ну тут 2 варианта 1 либо GetIndex выдает не индекс вообще, а на экране что ли 2 либо виртуализация и GetIndex выдался и не учитывает что нужно бы обновить себя.
С первым ничего не поделать. Со вторым нужна магия единорога.
Всем доброго времени суток! Пишу десктопные приложения на WPF, коммерческого опыта в программировании плюс минус два года. Сейчас возникло желание вкатиться в веб-разработку(ASP.NET). Можете дать, пожалуйста, совет, с чего лучше начать? И реально ли найти работу, например, бекенд разработчика с таким беграундом? Смотрела вакансии для Джуна, везде требуется коммерческий опыт веб-разработки, а стажироваться идти не вариант 😭
>>3296963 По моему опыту - тех кто вляпался в десктоп - лучше вообще к нормальному программированию не подпускать. Хуже только те кто в ембеддед вляпались или в гейдев.
Потому что я ебал ваши синглтоны и статические классы раскручивать, ебал вашу кашу, которая получается от того что все слои перемешаны так, что ебись оно конем. Короче. Хочешь в веб - начинай с самого начала, по гайдам для новичков и не выебывайся. Кто вляпался в десктоп - должен доказать, что хотя бы круд может написать не изговняков все своими десктопными привычками.
>>3296963 >с чего лучше начать? https://metanit.com/sharp/aspnet6/ Пройти по порядку, что непонятно или недостаточно разбирать в других источниках. >>3296963 >И реально ли найти работу, например, бекенд разработчика с таким беграундом? Только если очень повезет. Если дополнительно есть хороший опыт работы с EFCore и понимание как работает DI. Но все равно нужно учитывать, что вначале придется сильно ужаться по з.п.
>>3296972 > Потому что я ебал ваши синглтоны и статические классы раскручивать, ебал вашу кашу, которая получается от того что все слои перемешаны так, что ебись оно конем. Ну у меня вот нет синглтонов, всё через di, в том числе модели представления. Что не может быть создано через di (вью модели элементов списков например), создается через фабрики, внедряемые опять же через di. Всё как в вебе, нет?
>>3296972 >По моему опыту - тех кто вляпался в десктоп это твой личный опыт. >Потому что я ебал ваши синглтоны и статические классы раскручивать хз о чем ты вообще. >все своими десктопными привычками десктоп ничего не требует. а говнокодеры есть везде.
>>3296977 >Всё как в вебе, нет? да. кроме одного - времени жизни. в вебе - запрос пришел, родились scoped зависимости, запрос закончился, все это сдохло. То есть выполнился в скоупе в десктопе время жизни чего либо не имеет четкого выражения, поэтому убогий IoC скоуп по хорошему заменяется на лайфтаймы. Ну или по плохому на weak ссылки.
>>3296995 >айтишницы хоть мы и на дваче не будем просить пруфа. чай не в /b сидим
>>3297063 >это твой личный опыт Который ни разу не подвел. Стоит десктоперу залететь на веб-проект, как все в говне измазано.
> десктоп ничего не требует. а говнокодеры есть везде. Только вот те кто пишут десктоп особенно много говнокодят чаще. Потому что в среде десктопа - куча плохих практик, которым, блядь, прям учат новичков. И они потом весь профессиональный путь это с собой тягают.
Ладно, я не хочу спорить. Если тебе ок потом за ними убирать все то говно что они наделали - ну, флаг в руке. В мою команду, если залетает десктопер бывший, то только на позицию не выше джуна, и как минимум 3 месяца будет под пристальным надзором, чтобы за любой говняк сразу получать. Только так с ними можно выстроить процесс.
>>3297088 >Который ни разу не подвел и все равно остается личным. Ты так говоришь будто у тебя там 100тыщ миллионов десктоперов залетало. а по факту - у тебя все хреново, раз на веб проект десктоперов посылают
>Потому что в среде десктопа - куча плохих практи еще раз - десктоп НИЧЕГО не требует. Ну разве что винформсы, но даже они не требуют. Каждый пилит в меру своих умений
>Если тебе ок потом за ними убирать все то говно что они наделали - ну, флаг в руке зачем мне за ними убирать. я сам пишу под десктоп, бэкенд (причем на нескольких языках) и под мобилы и растом балуюсь. И когда мне теоретик говорит "десктоп навязывает", то...ну ты понял.
>>3316924 Если существует мультивыбор, то опрос не заслуживает внимания, потому что проводился среди хуесосов-фуллстакеров, которые не делают погоду на рыночке.
Я уже молчу о странной разнице между html и JavaScript. По логике, джава и штмл должны поменяться местами. Возможно, автор пикрилейтед — жирный тролль и отфотошопил пикчу. По логике, первым должен идти штмл, затем питон, затем джава скрипт, а уже дальше джава, шарп и скюэл. А на пикче просто аномалия.
Хочу видеть ссылку на оригинальную статью. Не продает ли автор курсы по джаве?
>>3317087 Прям представляю ебало кабана, который услышал, что больше нет бэкендеров, есть отдельно клнтроллерописатели, сервисописатели и SQL-щики, причём каждому платить по 300к.
>>3317846 Знаешь как это выглядит со стороны - врываешься такой ты в тред с транспарантом "смотрите я имбецил". А тебе говорят "ты говоришь что ты имбецил?". А ты такой - хаха вреттте
Коллеги, на тред >>3218883 (OP) вышел хотфикс. Предлагаю выкатить на прод миграцию по переходу в >>3218883 (OP). Не забывайте открывать тикеты в репортах если проебали шапку.
Запоздалый(Легитимный) перекот треда о лучшем языка на планете.
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
Прошлый тред: >>3097760 (OP)