>>3434117 >Какие же вы все - молодцы! Да! Так и есть. Ух, вот бы каждое утро просыпаться, а тебя хвалят и хвалят. >Как же джава хороша. Лучший язык на планете~~
>>3434087 (OP) Как изучить джаву без привязки к спрингу, если у меня уже есть опыт с другими ЯП? Чтобы мне не начинали в очередной раз пытаться рассказывать, что такое переменные, циклы, классы и прочее.
>>3434087 (OP) Как выживать на проектах, которые писали лоускильные ноунеймы из провинции? В очередной раз попал в болото из Контроллер - МайСервисИмпл имплементс МайСервис - Рипазитари. Вся логика, разумеется, в сервисе. Сервис - файл на 3.5-5к строк. Тесты? Какие тесты? Сервис и бизнес-логика завязаны на другие сервисы, а они на другие сервисы, а они на друг... Юнит-тестов нет, интеграционных тестов нет. Обещают переписать на микросервисы и тогда все заверт.. но воз и ныне там. Релиз раз в полгода, ручной регрес и жалкие попытки энд ту энд со стороны куашников. Ливать?
>>3434143 >Как выживать А что тебя на таком проекте убивает - пойми это для начала?
Так то у тебя один из двух стульев:
Либо мимикрируй под остальных долбоебов и не отсвечивай, Приходи-уходи на работу по графику. Не овертаймь, не рви жопу, ни с кем не спорь, в залупу не лезь. Лутай тихонечко свой оклад, параллельно качайся, ищи альтерннативы, и годика через 2 сваливай.
Либо наоборот максимально лезь в залупу, но по умному. Общайся с стейкхолдерами, понимай что их устраивает не устраивает, предлагай инициативы, выбивай себе большие свободы и полномочия, подминай под себя лоускиллов и учи их хорошим практикам. Это путь high risk high reward - ибо инициатива ебет инициатора. Если ты сам лоускилльный, особенно это касается софт скиллов, тебя просто затраллят и либо ты сам выгоришь и сопьешься, либо тебя начальство отстрелит как токсика.
>>3434187 >Для синтаксиса, как я понимаю Для именно синтаксиса ты можешь буквально что угодно открыть, начиная туториала оракла, хорстмана, шилдта, заканчивая вовсе жаварашем каким-нибудь. Вообще не приципиально как по мне, он учится в первую неделю, если ты уже имеешь опыт других яп. По кишкам есть, например, конференции jpoint и вот у шипилева классные выходили https://youtube.com/playlist?list=PLecCTjz_4ylyyvYExhPAzB4Mqn3Q_kEj6 Можешь начать с этого, как по мне, если ты хоть что-то начнешь смотреть/читать, то источники по этой или смежной теме ты так или иначе найдешь через ссылки в этих же источниках. Просто типичная история, а вот подробнее об этом читайте туть, это не тема книги/конференции и тд.
> В очередной раз попал в болото из Контроллер - МайСервисИмпл имплементс МайСервис - Рипазитари.
Давай конкретный пример. В целом в этом нет ничего плохого.
> Вся логика, разумеется, в сервисе.
Всё верно. А где ей ещё быть? Не в контроллере же. Не в репозитории же.
> Сервис - файл на 3.5-5к строк.
Многовато, но открой серьёзный проект, там одни интерфейсы по 1000 строк, правда 90% это документация. Если нет дублирования кода в классе на 5,000 строк нет ничего плохого.
> Сервис и бизнес-логика завязаны на другие сервисы, а они на другие сервисы, а они на друг...
Это и называется слой бизнес логики. Можно взять целиком все эти сервисы и перенести в другой проект в виде библиотеки и вся бизнес логика будет работать без проблем.
Есть нечто смешное в том, что в ответ на высокую связность ты слету ответил что это нормально, мол именно так и проектируется бизнес логика, а вот момент с отсутствием юнит тестов у анона вообще никак не прокомментировал.
Потому что отсутствие тестов это плохо, что тут ещё комментировать. Пишут серьёзную большую программу и даже просто сами для себя не хотят проверить всё ли в ней работает как надо.
Заказчикам видимо тоже пофигу на это. Если у них чё-то не работает они просто поднимают трубку, звонят и им всё чинят.
Может там руководство и вообще работа в целом построена так, что они не считают нужным тратить время на тесты, ведь это удлиннить сроки в полтора-два раза а значит всё это время придётся оплачивать труд кнопкодавов, а бюджет и так мизерный, да с него ещё и откатить надо половину.
А может там вообще уже давно ничего нового и не делают, просто работает прога и нужен чел который будет туда иногда новые функции добавлять пару раз в год.
В общем я бы избегал такой работы если хочется развиваться как специалист.
Ни какого CI/CD и прочих современных практик, ставших уже нормой во всём мире, там видимо тоже нет.
А значит опыт который там анон получает не является коммерческим опытом разработки. А значит в другой серьёзной компании этот опыт учитываться не будет.
>>3434087 (OP) Чем плох ЮВАО? Погулял по картам по Перово и Измайлово - лампово. Чистенько, пешеходная инфраструктура есть, все эти пандусы, тротуары, ровные дороги, чистые улицы. Дома в основном невысокие - мало панелек, рядом лесопарк. Открыл престижные Раменки и Крылатское - ну такое. Куча хрущей, которые давят сверху и как-то неуютно..
>>3434191 Ну, т.е. ты не в курсе про SRP, low coupling, high cohesion? То, что у тебя один такой сервис на 5к строк зависит от 3-5 еще таких же сервисов на 5к строк каждый, а те тоже зависят от сервисов..
>>3434319 >замокать реализацию Ох уж эти "юнит тесты" где мокают все прямые зависимости и начинают "тестировать". А потом бегают и плачутся, что тесты у них хрупкие и их нужно переписывать на каждый чих
>>3434143 Ты на работу идёшь за деньгами. Пока твоё личное уважение к себе не ставят под сомнение я не вижу смысла воротить нос хоть от чего-либо. Говнокод это проблема кабанья, ты что с чистым, что с говном тратишь 8 часов в день.
Проблема мокирования, которую затронул автор саркастичного сообщения, связана с чрезмерным использованием моков в юнит-тестах, что приводит к хрупким и бесполезным тестам. Вот основные аспекты этой проблемы:
### 1. Тесты становятся хрупкими (fragile) - Если замоканы все зависимости, то любое изменение в логике кода (даже корректное) ломает тесты, потому что моки жёстко завязаны на текущую реализацию. - Пример: поменяли порядок вызовов методов или добавили новый – тесты падают, хотя бизнес-логика работает правильно.
### 2. Тесты не ловят реальные баги - Моки подменяют реальное поведение зависимостей, поэтому тесты проверяют не "как код работает", а "как он представлен в голове тестирующего". - Пример: - Замокали базу данных → тест проходит, но в реальности SQL-запрос синтаксически неверен. - Замокали внешний API → код работает с моком, но падает при реальном запросе из-за неучтённых полей в JSON.
### 3. Тесты превращаются в "ритуал" - Вместо проверки логики тесты начинают просто верифицировать, что вызывались конкретные моки. - Пример: ```python # Плохо: тест не проверяет логику, только факт вызова мока mock_db.insert.assert_called_once_with(data) # А если метод поменяет название? ``` Такой тест не упадёт, даже если код полностью сломан, но не вызвал именно этот метод.
### 4. Избыточная изоляция - Юнит-тесты должны проверять логику модуля, но не обязательно изолировать все-все зависимости. - Часто лучше использовать real-объекты (например, настоящие классы-сервисы без I/O) или стабы (заглушки с предсказуемым поведением), а не моки.
### Когда моки действительно нужны? - Внешние сервисы (API, базы данных, файловая система). - Опасные операции (например, удаление данных). - Сложные зависимости, которые трудно настроить в тестах (например, аутентификация).
### Что делать вместо моков? 1. Писать интеграционные тесты – для проверки взаимодействия между модулями. 2. Использовать фейки (fake) – упрощённые, но рабочие реализации (например, in-memory база вместо PostgreSQL). 3. Тестировать поведение, а не реализацию – проверять результат, а не "как именно он был получен".
>>3434257 Правильно, хули, никто не спорит что отсутствие тестов это плохо. Другое дело что обычно в таких вот проектах с ебейшим транзитивным каплингом юнит тестов как раз и нету никогда, и нет их как раз из-за ебейшей связанности спроинговых компонент, из-за которой у анона просто не остается ручек, чтобы изолировать компонент под тесты. Но у культа такая связность - это норма, как ты отметил.
Но ты очень забавно ушел от темы, повеселил. Буквально свалил вину на всех - и начальство то виновато, и заказчик, и легасятина... Целое полотнище выводов вон настругал. Что называется, за деревьями леса не видать.
Я просто поражаюсь иной раз тому, как спрингокульт любит пиздеть о важности юнит тестирования, но при этом никогда не писать юнит тесты.
>>3434270 Забей. Солид в устах спрингофагов - инструмент демагогии, не больше. Чекни борисовский "спринг-построитель" на 15й минуте, его пук-среньк позорный по SOLIDу. А это - один из их главных гуру. Если спрингоблять раскрыла рот и начала перечислять при тебе принципы SOLID в контексте их фреймворка, она почти гарантированно не выкупает, какой шизоидный религиозный бред она несет.
>>3434386 >какой шизоидный религиозный бред она несет А разве так не со всеми этими принципами, которые произносят как мантру? SOLID, KISS, PIDOR вот если следовать умным советам из книг написанных кучу лет назад, то ну тооочно все станет лучше. Там ведь хуйни не напишут
Ну а как не плодить эти сервисы и не каплить? Вот я вчера решал задачу. Есть 30 установок программы в 30 разных организациях. Заказчик не может заставить их обновляться, хотят обновляются, не хотят не обновляются, их право. Соответственно есть 30 постгрес баз приложения и разброс версий этой базы 11 разных версий. Уплочено за поддержку всего этого и плотится ежегодно. А мне нужно сделать небольшую прогу, которая может подключиться к любой базе и делать кое-какие действия в ней. То есть мне нужно реализовать поддержку на данный момент 11 разных версий базы, в каждой версии какие-то таблицы есть, каких-то нет, какие-то поля в таблицах есть, каких-то нет.
Сделал СЕРВИС, который по версии базы из конфига возвращает имя роута, который ведёт к контроллеру, который отвечает за работу с той или иной версией базы.
Ну а как это ещё решить? Ну не делай сервис сделай switch чё легче станет что ли. А так хотя бы этот свич лежит отдельно в отдельном классе.
Прилетает запрос в котором в такую-то организацию нужно добавить такое-то значение. И не ебёт клиент какая там версия базы. И сегодня в этой организации одна версия базы, а завтра их переклинит они обновятся и будет более свежая.
Да и будет теперь кругом лезть этот СЕРВИС и всё будут от него коуплится.
>>3434406 Ну ок, ты хотя бы не культист и в отрицалово не уходишь, есть надежда на конструктивный диалог.
>Ну а как это ещё решить?
А никак. В терминах спринговых реалий это тупо не решаемо. По совести, каждое из этих вот "кое каких действий", какие ты выполняешь в своей проге, хорошо было бы держать в таком виде, в каком их можно было бы черрипикать и переиспользовать независимо друг от друга. Не инжектить сервис из 5 тысяч строк, а затащить себе в клиентский компонент только ту часть, которая тебе нужна. Тогда количество зависимостей каждой из таких вот мини-компонент можно было бы свести к минимуму, и такой компонент можно было бы переиспользовать максимально гибко, не тащя за собой лапшу из остальных компонент. В терминах distance from main sequence меньше входящих транзитивных зависимостей == меньшая ригидность компонента == большая переиспользуемость и меньше риск того, что какие то из этих зависимостей изменятся и приведут к регрессиям в клиенте. В конечном итоге получилось бы нечто схожее с функциональной композицией, но на классах.
Но в спринге же так не принято - мы же в таком случае будем "плодить компоненты", айяйяй! Запутаемся, бедненькие, потеряемся! Мы попросту не можем не обьединять методы, которые хотим переиспользовать, по каким то абсурдным критериям типа "коли этот метод про пользователя, значит он должен быть частью UserService". А наобъединявшись, не можем потом переиспользовать то что наобьединяли. Вдовесок мы все это еще обвешаем аннотациями, чтобы компоненты приколотились друг к другу по декларациям инжекций и заодно вся бизнеслогика вендорлокнулась на фреймворк (слава богу эта мода потихоньку уходит в прошлое уступая место бутовым автоконфигурациям).
Я так то не оторванный от реалий идеалист, все могу понять. Просто в ебаном культе меня всю дорогу бесила вот именно эта пиздабольско-демагоговая манера. Нихуя такой дизайн не норма, и SOLIDом там даже близко не пахло. Это просто сложившаяся исторически говенная данность, где мы все варимся. Вот ты хотя бы признал что "да, хуево, но хуй знат как иначе", это я по человечески могу понять. А большинство долбоебов щас будет на говно исходить пытаясь доказать мне что это я просто не преисполнился и должен спринг выучить.
>>3434517 Сложно только из-за того, что некоторые вещи реализовали раньше, чем в джаве, а потом из в джаве реализовали по другому (замыкания - лямбды) и на стыке языков не очень удобно работать. А так обычный скриптовый язык. Есть аналог шарпового LINQ.
Каким же гауном бесполезным джава 25 будет. Хоть бы блядь флексибл конструктор бодис в стейбл завезли, а то пиздец же, одни поломки совместимости и выпиливания.
Почему mvnd даёт такой маленький прирост производительности в сравнении с правильно настроенным обычным мавеном? Вормап жи, волшебный JIT жи. Обычный параллельный 16 секунд, демон 12-13.
Кому эти 3 секунды всрались особенно когда добавляется ещё один источник непонятных багов?
>>3434607 Причём я не вижу особо даже обещанной магической инкрементальности. Делаю изменения, компилирую, 13 секунд, не делаю, просто подряд компилирую, всё равно по 13 секунд. Что я делаю не так? Проект маленький относительно, но модулей много, параллелить и инкрементить есть что.
>>3434611 Немного, но часто и этого не делают. Параллельность билда, плагины отпердолить чтобы с параллельностью работали, потом выбирать только нужное через -pl <name> -am. У меня так, мб что-то ещё можно.
>>3434618 > Удачи потом логи компиляции/тестов смотреть на CI Так плагины просто не используй каловые.
> Полтора плагина умеют в параллельные сборки. Остальные тупо тыквят твой билд А тебе много плагинов нужно? Много нужно классических плагинов, эта портянка с компайл шейд ресурс хуюрс и т.д, они все поддерживают нормально, а те что под проект их как раз и полтора и используется.
> Экономия на спичках. Если у тебя сильно горизонтальный проект или вообще монорепа то очень полезно.
> Просто нужно понять, что джава это не про экономию времени и быструю разработку. Тут в порядке вещей билды по часу-полтора и прочие приколдэсы А, так ты очередной залётный школодегенерат с фантазиями и проекциями. Ясно.
>>3434621 >Так плагины просто не используй каловые. А других нет. Это же джава
>А тебе много плагинов нужно? Те, что использую не умеют в параллель
>Если у тебя сильно горизонтальный проект или вообще монорепа то очень полезно. Полезно кому? Выше анон сокрушался, что попал на каловый проект где хуй проссышь как код писать и архитектура говна. По факту этот все верно сказал >>3434339 - на работу нужно ходить за деньгами. Если тебе повезло с коллегами и проектом, то может чего-нибудь почерпнешь для себя и научишься новому. Нет? Просто лутай бабки и не отсвечивай. Все эти попытки "улучшить проект" до добра не доводят.
>>3434626 > А других нет. Это же джава По моему джава это как раз про 100500 способов пёрнуть в трубочку.
> Те, что использую не умеют в параллель А ты хотя б пробовал их настраивать? Или обновлять. Или альтернативы искать. Или хотя бы понять какой конкретно плагин не могёт.
> Полезно кому? Выше анон сокрушался, что попал на каловый проект где хуй проссышь как код писать и архитектура говна. По факту этот все верно сказал >>3434339 - на работу нужно ходить за деньгами. Если тебе повезло с коллегами и проектом, то может чего-нибудь почерпнешь для себя и научишься новому. Нет? Просто лутай бабки и не отсвечивай. Все эти попытки "улучшить проект" до добра не доводят. Блядь, ну это другой вопрос, что работнику на говноработе обосновано вола с суровым видом ебать. Тут речь идёт в принципе о том инструмент полезен или нет.
>>3434627 >Или альтернативы искать Зачем? У меня нет цели сделать проект кабана лучше, если я встречаю лишь агрессию и непонимание со стороны команды и руководства. Мне проще плыть по течению, а в свободное время ковыряться во всем этом.
>>3435166 Что в нем такого уж плохого? Просто не надо юзать весь тот безумный объем пиздеца, который туда напихали разрабы, и будет норм. По сути, можно сказать что джава это подмножество груви. То есть и жава тоже кал говна получается?
>>3435175 Очень сложный язык с огромным количеством фич, тремя парадигмами и мега фреймворками как ZIO, cats и akka, которые все еще сильнее усложняют и специализируют. На ней пишет очень мало людей, и все по-разному.
В скале много интересных идей, но язык очень непрактичный.
>>3434608 Прихожу с обновлениями. Мне напиздели, инкрементальности в мвнд и не было никогда. Зато есть в такари, старичок до сих пор работает. За 7,5 секунд теперь билдится без изменений и 9 с изменениями. 20 немаленьких модулей в проекте.
Ебало градлодебилов которые страдают со скриптобилдами из-за "скорости" (которой нет, потому что первый билд на градле это пиздец, можно чай уходить пить, а когда вернуться видеть build failed) к осмотру.
>>3435388 А что там читать? Вроде всё стабильно. Есть какая-то хуйня что мвнд хуеет когда сильно помник меняешь разом, но mvnd --stop спасает, даже читать не надо ничё, к тому же помник с полунуля ты редко переписываешь.
>>3435388 Что вы с этими логами параллельной сборки носитесь? Упал билд - запусти однопоточный билд, делов-то. А если у вас каждый второй билд падает, то проблема не в мавене.
Подскажите, на сколько распространённая практика мультимодульности? У вас лично это используется? Все модули лежат в одной репе или в нескольких разных?
>>3435454 >>3435428 При параллельной сборке у тебя логи пишутся из нескольких потоков в терминал или лог файл на CI и по итогу у тебя там каша. Если билд упадет, то потом хуй разберешься где что зафейлилось
>>3435462 Зависит от контекста. Если никакие артефакты наружу не нужно отдавать, то лучше все хранить в одном модуле и разделение сделать на уровне пакетов. Однажды я попал на проект, где лид обезумел и начал нарезать модули внутри проекта. Когда я увольнялся, в проекте было больше 60 модулей и ни один из них не использовался вне проекта
Не, речь именно о том, чтобы раздавать. Допустим есть модуль, в котором есть логика, позволяющая добавлять таски в информационную систему. Ты можешь этот модуль приделать к проекту графического приложения десктопного. Можешь приделать к веб-сервису. Можешь приделать к сайту. Добавление такски всегда одно и то же. Но проекты десктопного приложения, веб-сервиса и сайта это разные проекты.
>>3435470 В первую очередь при параллельной сборке демоном вообще нихуя никуда не пишется пока не собралось. Записывается уже после сборки. Наверняка что-то придумали для ошибок раз научились логами управлять, потому что пока я наворачивал эту параллельную сборку я миллион фейлов наловил и всё получалось читать.
>>3435470 >При параллельной сборке у тебя логи пишутся из нескольких потоков в терминал или лог файл на CI и по итогу у тебя там каша. Если билд упадет, то потом хуй разберешься где что зафейлилось У тебя при паралельном чтении постов, фразы смешиваются и в голове полная каша, которую хрен поймёшь. >Упал билд - запусти однопоточный билд, делов-то. А если у вас каждый второй билд падает, то проблема не в мавене.
>>3435462 Ты про какие модули спрашиваешь? Про JPMS? Или тупо про какие нибудь мавен-модули?
>У вас лично это используется?
Мавен проекты на модули обязательно делим - чтоб прям со старта корневой модуль был packaging=pom. Есть ряд монолитных проектов, но на пользу им эта монолитность нихуя не пошла, когда руки дойдут - поделим и их. Вообще, за packaging=jar в корневом помнике впору по рукам бить.
>Все модули лежат в одной репе или в нескольких разных?
Одно с другим не связано. Разбиение по репам скорее - вопрос организации всяких бранчингов, релизных циклов и прочих процессов. Сама по себе самоцель разносить модули по разным репам обычно не имеет под собой никакого смысла.
Лично у нас - реп под один продукт либо реп под одну команду. Периодически бывает что ряд модулей переезжает в отдельный реп или из репа в реп.
>>3436390 > Вообще, за packaging=jar в корневом помнике впору по рукам бить. Что за хуйню ты несёшь, долбоёб? Не из тех ли ты дегенератов что в десятых носились по всему интернету и орали о том какое зло instanceof?
>>3436396 Нет, не из тех. Против instanceof ничего не имею. А вот из-за долбоебизма предтеч, не сделавших элементарную вещь которая упростила бы все будущие рефакторинги, пару раз приходилось расхлебывать последствия.
>>3436408 >превентивное разделение на модули Ты где про превентивные модули вычитал в фразе "за packaging=jar в корневом помнике впору по рукам бить"? Нет буквально ничего сложного в том, чтобы сделать корневой помник packaging=pom. Какие нахуй преждевременные модули?
>упростит хоть какие-то рефакторинги? А ты че - никогда не рефачил полотнища монолитного помника, где намешаны и депенденси с их версиями, и стопятцот плагинов делающих все - от стайлчекинга до билда конечных сборок через какой нибудь ассемблай с антовыми вставками? Может быть правил что нибудь в таком месиве?
С корневым помником у тебя хотя бы есть инструмент, через который ты можешь зависимости от билд пайплайна быстро и легко отделить, для начала. А если есть скилл, можно вообще весь билд пайплайн аккуратненько в руте по профайлам разложить так, что все помники по читабельности будут по читабельности грыдле давать пососать.
>>3436423 > Ты где про превентивные модули вычитал в фразе "за packaging=jar в корневом помнике впору по рукам бить"? Нет буквально ничего сложного в том, чтобы сделать корневой помник packaging=pom. Какие нахуй преждевременные модули? Ты куда код будешь писать, когда сделаешь корень pom'ом, долбоёб? В один из modules. Или в твоём случае единственный, что терминальная стадия шизофрении.
> А ты че - никогда не рефачил полотнища монолитного помника, где намешаны и депенденси с их версиями, и стопятцот плагинов делающих все - от стайлчекинга до билда конечных сборок через какой нибудь ассемблай с антовыми вставками? Может быть правил что нибудь в таком месиве? Каким образом это к твоему высеру на jar в руте относится? Каким образом перетаскивание всего этого на уровень ниже поможет?
> через который ты можешь зависимости от билд пайплайна быстро и легко отделить, для начала. У тебя этим занимается разделение блоков build и dependencies. Ей богу олигофрен.
> А если есть скилл, можно вообще весь билд пайплайн аккуратненько в руте по профайлам разложить так, что все помники по читабельности будут по читабельности грыдле давать пососать. О каком скилле ты высираешь, если у тебя модульность выполняет задачу разноса зависимостей и билда на разные файлы? Высер про градл это вообще пиздец. С каких пор блядь градл стал читаемее мавена? Он блядь всегда был нечитаем, это его главный недостаток сука был всегда.
Блядь, какой же идиот, постоянно приходит в тред и несёт такую хуйню что появляются вопросы а не ии ли это серет. Буквально тот самый омеган что пытается "за компанию" в разговор встрять и несёт околесицу от которой всем (кроме него самого) стыдно.
Да хули я распинаюсь блять перед каким то двачевым недоноском. У меня на проекте ты бы тише травы ниже воды сидел, чмо, либо с переломанными руками. Не хошь вести конструктивный диалог - пошел нахуй. Можешь слив еще засчитать как вы, двачевые дегенераты любите.
>>3436457 Привыкай пропускать мимо ушей оскорбления, ты же на сосаче, а то всегда придётся грызтись вместо попыток в разговор по сути. К тому же заслужил, ты ж несёшь хуйню полную.
>>3436467 Да мне похуй, че решил для себя то и несу. Шарю свой опыт анону, который задал вопрос, ни больше ни меньше. Мне ни тепло ни холодно от того, что недоносок двачевый мой пойнт не выкупил - у меня на проекте помники от этого свой пэкеджинг не поменяют.
В общем, ситуация такая, у меня две бд - эластик и постгря и из-за особенностей эластика мне нада сделать сагу. Предметная область база знаний, записки там и тд, ничего интересного.
Долго лежал, плевал в потолок, как бы это получше организовать архитектурно. В итоге пришел к такой структуре: Есть базовая табличка notes, куда я кладу иммутабельные или уникальные поля, типа владельца, пути до заметки и прочей поеботы. Эта заметка так или иначе имеет связь с состоянием. Состояние - это жизненный цикл заметки, типа `CREATE -> UPDATE -> UPDATE -> ...`. Т.е. если я захочу изменить контент внутри заметки мне сначала нада создать новый стейт в таблице note_states и перепривязать (закоммитить) это новое состояние заместо старого в таблицу notes. Поскольку у меня есть два состояния и новое и старое, предполагаю, что тут вполне можно ебануть оптимистик локи.
Так вот, тут я думаю и вступает в дело сага. Т.е. я сначала создаю новый стейт. А потом запись, что надо бы закоммитить вместо старого стейта, на новый такую-то запись в notes. А потом отправляю это в кафку, которая эвент создаст. Теперь, в saga_logs будут созадаваться записи типа CREATE IN ELASTIC -> REINDEX -> COMMIT IN ELASTIC -> COMMIT IN DB -> DONE На любом этапе, если выяснится, что state_old_id не совпадает с тем, что лежит в notes или просто произошел пиздец, можно легко откатить все действия. Также я планирую создавать в elastic под каждый стейт новый документ и наделять его состоянием типа COMMITED/UNCOMMITED. Таким образом я не не закорапчу поиск, поскольку все незакоммиченные можно просто отфильтровать да и вообще можно будет удалять незакоммиченные документы. Также сначала получается будут этапы создания документов, а потом два этапа коммита сначала в эластике, а потом в бд, что +- атомарно.
Насколько ебанутая схема и далеко от бест практис?
>>3436564 У меня в эластике векторный семантический поисковик (rubert-tiny2). Не получится такое в постгрю запихнуть. Тут или наоборот все в эластик переместить, но.. У меня есть many-to-many связи в виде тегов. Да и это чисто петпроектик, почему бы не попробовать научится писать сагу.. >>3436549 Мех
>>3436492 А для тебя прям критически важна согласованность поискового индекса с данными в базе? Может ну ее эту сагу? Ну выдаст те индекс несуществующую в базе сущность в моменте - выкинешь ее из выборки перед отдачей и норм. Гугл же тоже твой бложек не сразу проиндексирует.
>>3436577 Проблема в том что несогласованность будет только расти. А чтобы не росла нужно отменять, а лучшее время для отмены это сразу как только было понято что будет несогласованность, т.е. в саге.
>>3436492 Когда нужно коммитить в две базы, то просто пушат месседж в кафку, а оттуда уже читают и пишут в постгрю и прочие эластики. Ты просто не читал кабана, чел.. Ты слаб и тебе нужно тренироваться
>>3436608 Ну она будет расти если ты совсем хуй забьешь. Я просто веду к тому, что индекс можно и независимо от отдельных коммитов в дб делать. Грубо говоря: пусть круд крудит на базе + каким то образом ведет учет того, какие сущности следует переиндексировать (хотя бы теми же эвентами в кафке, или флагом в таблице - не суть). А параллельно с крудом - по скедулу, например - выгребаешь все что нужно индексировать и индексируешь.
>>3436629 >Ты просто не читал кабана, чел.. Какая глава? Там про сагу не слова, а 2PC не подходит, потому что это эластик. >>3436637 Хороший вариант, у меня получается, если пользователь сохранил новое состояние заметки, дождавшись подтверждения, то перезагрузив страницу он будет видить старое состояние страницы, до тех пор, пока не будет завершена индексация. В твоем варианте он сразу увидит нормальное состояние, но поиск будет выдывать иногда бред, пока не будет завершена индексация. По сути надо выбрать, где бы наебать пользователя, навернооое твой вариант все таки лучше. Думаю оставить note_states, поскольку я хотел пристроить это также для функционала сохранения истории и отката к прошлым версиям. Табличка commits, не нужна, а saga_logs по сути просто логи будет вести. Т.е. в итоге, я создаю запись в note_states и коммичу её в notes и меняю поле indexed на false. Потом сабмичу эвент в кафку, мол надо заиндексировать такой-то note_states.id в такой-то notes.id с бэкофом. Теперь она будет долбится до победного, пока не закончаться попытки или state_id сменится на другой. Также можно делать `update notes set indexed=true where id=? and commit_to=?` и ну гарантировать в какой-то степени, что не будет ABA проблемы, типа когда во время индексации пользователь обновит табличку (false -> false), и индексатор запишет true = false -> false -> true, хотя в итоге должно быть false.
В сущности вся разница будет только в том, что я созаю индивидуальную тасочку для каждой индексации, а у тебя будет большая такая таска для всех записок сразу. Хрен знает что лучше, но я хотел с кафкой поработать хоть немного, поэтому выберу первый вариант. И пасиба за рекомендацию~
>>3436733 Ты блин, так сказал... как отрезал нах. "Поиск будет выдавать бред"... Ну гугл тащемто тоже иногда выдает бред. На это можно двояко смотреть. Обязательная перестройка индекса на каждый апдейт твоих ноутсов может быть как бенефитом архитектуры, так и изьяном. Второе возможно если у тебя эти ноутсы большие и часто обновляются - тогда апдейт индекса будет отжирать у тебя производительность - если есть вебморда, возможно она начнет лагать. В то время как откапли ты перестройку индекса, сделай ее отдельным батчем раз в минуту, и тогда если за минуту чувак накидал те пять обновлений, индекс один хер перестроится один раз по последнему апдейту, а чувак не факт что что-то заметит, либо ему будет похуй.
Что могут на собесе спросить про кафку? У меня на прошлом месте была кафка, но я ее просто отключал при дебаге, чтобы не мешалась, чё она делала хз. Что можно рассказать про нее? Как ее используют в реальности? Вот так? @Autowired private final KafkaTemplate<String, String> kafkaTemplate; public void send(String topic, String message) { kafkaTemplate.send(topic, message); } И вот тут шлем в нее и читаем @RestController public class MessageController { private final Sender sender; private final MessageConsumer consumer;
>>3436807 Нуу, можно абстрактно это как-нибудь обозвать. Типа "синхронизировать". Что синхронизировать, с кем синхронизировать вопрос третьестепенный. В общем спасиба еще раз, надо по быстренькому хоть что-то накидать..
Это же стандартное решение. Получение сущности по id должно возвращать всегда последнюю версию, но поиск по изменённым полям может немного запаздывать. Та же монга так сделана, да и многие другие движки баз тоже. мимо
>>3436846 Я те просто намекнул, что двачеру какбэ во первых похуй, во вторых не его собачье дело, че у тебя там за кухня на бэкенде творится. Ты щас петоводишь, молодой и шутливый - у тебя еще есть опция попытаться решить проблему типично программерским методом. А тем временем реальный проект может быть упорот по UI/UX, и вообще вся галера ориентирована на клиента. Тогда тебе эту странную кнопку попросту не дадут добавить.
>>3436774 Перестройка чего-либо по таймеру это всегда дегенеративный подход ибо ты регулярно будешь обрабатывать данные что не нужно обрабатывать никоим боком. Нужно реагировать.
>>3437299 Ну с моей т.з. это просто откладывание момента обработки, причем централизованным способом. Что-то типа гц, который по кд собирает мусор. Почему этот подход дегенеративный мне не совсем понятно, раскрой мысль. В принципе-то, если разбивать все на сингл таски и пихать это в кафку, то можно более точечно контролировать потребление, поскольку это очередь же.
>>3437316 Так гц (по крайней мере классические, не знаю про новые подходы типо zgc, мб там что-то поменялось коли обещают независимость от размера кучи кала) тоже дегенеративен. Обойти всю кучу чтобы понять что отвалилось, вместо того чтобы сигналить когда что отваливается, ну не пиздец ли же.
>>3437318 Зато это значительно упрощает работу с памятью для языков. Трейдофф между простотой и перфомансом/красотой. Для тебя я так понимаю пик эволюции обработки мусора - это борроу чекер или эти умные указатели?
Иногда приходится делать задания по таймеру. Иного пути нет. Например, я делал интеграцию с системой, в которой в таблице в базе данных выставлялся статус что такой-то документ готов к отправке по api и мне нужно было его считать, сформировать запрос и отправить по api. Это нельзя никак решить иначе кроме как поллингом по таймеру где будет селект из этой таблицы. Никто никакого события тебе генерить не будет и колбеков ни каких вызывать тоже, обычная база данных MySQL 5.5 и в ней таблица. Всё. Делай.
>>3437568 Тащемто нет. Я прекрасно осознаю что есть ситуации в которых локально человек нихуя не сможет сделать. Смысл был в том что глобально всегда есть решение лучше, и подумать над тем на самом ли деле ты ограничен в возможностях или можно сделать получше стоит.
>>3437619 Мне кажется это нейронка. >>3437617 Ну жаба действительно не позволяет перегружать ==, причем чисто принципиально, поэтому для структурного сравнения, тебе надо equals. Но этот метод можно сгенерировать, через тот же record. Не понимаю к чему тут вообще приплели делегаты, поскольку функциональный тип, как известно, одно из немногих исключений,к который в теории типов принципиально не обладает свойством эквивалентности = его нельзя сравинвать и к нему ты не сможешь написать корректный equals метод. Ну и ты можешь неявно наследовать, пик.
>>3437621 > в теории типов В какой ещё теории типов? В твоей влажной?
> его нельзя сравинвать и к нему ты не сможешь написать корректный equals метод. По моему он скорее не нужен. Написать то наоборот просто, сравнивай класс и всё.
>>3437622 >В какой ещё теории типов? Хм.. Ну да, есть же альфа эквивалентность, ну и eta conversion, хотя имплементация подобного.. Ну немного затруднительна. >сравнивай класс и всё Этого не хватит, лямбда же может захватить что-то с разными значениями. Причем более того, тебе нигде в спеке не гарантируется, что лямбды и дальше будут имплементироваться через анонимные классы и также там есть приписка, что это вэлью классы, и поэтому пожалуйста, не используйте лямбды в synchronized и не используйте с ними ==, посколку они могут в будущем не иметь identity. >>3437629 Ну да, но это в принципе и правда не нужно. Мне просто непонятно как мы от сравнения пришли к делегатам..
Но мне не повезло, потому что лямбды в джаве на уровне байткода вместо каноничных анонимных классов (в которые даже можно откатиться с помощью какой нить ретролямбды) выполнены в виде метафакторно-бутстрапной хрени на инвокдинамиках, и я никак не могу сгенерить для инстанса лямбды equals... а как сука хочется...
>>3437634 Долго рассказывать. Делал я просто один экспериментальный тул... и все нравится в нем, но лямбды сука всю мазу ломают вот этой вот своей особенностью...
>>3437621 >функциональный тип, как известно, одно из немногих исключений,к который в теории типов принципиально не обладает свойством эквивалентности Всё это как водится, был пиздеж.
В теории функциональные типы прекрасно сравниваются: если для любой комбинации входных параметров, они выдают одинаковый результат, то типы эквивалентны. Просто на практике такую проверку эквивалентности, за разумное время, реализовать пока не получается. Но в теории всё как раз работает.
>>3437761 Ну да, ты прав, я сам про енто написал в следующем посте. Просто предположил из основания, что Eq тайпкласс в хачкеле не сделан для стрелок, ну и вот чет предположение построил.. Давно все таки теорию не пересматривал, год прошёл уже.. эх, даже грустно что-то..
Сап, подскажите по зарплатам. Я, имея 2 года опыта, когда устраивался в компанию, запрашивал 100к. Несколько месяцев уже работаю, но корёжит от мыслей, что мог больше запросить. На хабре вообще заоблачные цифры, хотя там в фильтрах нельзя указать количество лет опыта, только ебанутые термины типа джун мидл, я судя по нему меньше джуна получаю. Однако я из Беларуси, тут поскромнее зарплаты, но не настолько же. Может ли работадатель спустя 9 месяцев на перформанс ревью зп где-то на 60% поднять или только работу новую искать? Хотя я даже хз 60% это я опять мелочусь или дохуя хочу
>>3437761 >Просто на практике такую проверку эквивалентности, за разумное время, реализовать пока не получается. Но в теории всё как раз работает. Это в общем случае невозможно из-за проблемы остановки.
>>3437850 Да чё ты этого школьника слушаешь. Кто заставляет его сравнивать по поведению? По непосредственному коду (ну и замыканиям, хули, хотя это выглядит как какой-то сахар который в типы не лезет) сравнить и всё, в реальности даже код сравнивать не надо потому что есть классы. Только это никому не нужно. Нахуй блядь сравнивать лямбды?
>>3437876 >По непосредственному коду Проблема такого подхода в том, что если в тупую сравнивать, то лямбды типа _ -> 1 + 9 _ -> 5 + 5 Будут ну совершенно разными и как их вообще можно сравнивать-то >даже код сравнивать не надо потому что есть классы А это предложение еще лучше, поскольку даже полностью идентичные лямбды, но созданные в разных местах будут иметь разные классы.
В общем смысле, наверное надо привести к нормальной форме сначала, если нормальные формы совпадают, то они эквивалентны.
>>3437840 Как потопаешь, так и полопаешь. У тебя всегда есть опция сменить работу, другое дело - будут ли тебе вообще где либо платить столько, сколько ты хочешь. 2 года опыта - ниочем, некоторые сеньки и за 10 лет реальной экспертизы и кгомпетенций за душой не имеют. Так что я б на твоем месте как минимум не корежился в саморефлексии. Устроился - уже хорошо. Многие вон и устроиться не могут...
Там древняя как сам MySQL так и сервак, который к нему имеет доступ. Ну даже если получится пробить через безопасников что я к этой базе буду подключаться с другой виртуалки, более современной, то всё равно исходная база на 10 летней давности MySQL и обновляться там никто не хочет, слишком трудозатратно. Такие системы наверное обычно живут до конца а потом их выкидывают и делают новые. Так что while(true) sleep(timeout) ...
Последние года на весь /pr/ стоит вой вкатунов. Не ебу кто все эти люди, но хз каким глухим и слепым надо быть чтобы эту хуету не замечать. Наверное все это ж-ж-ж - неспроста...
>>3438181 Самое рофляное там даже не подключение с другой виртуалки. Чтоб дебезиум работал, надо на БД бинлог включать, и вот здесь то уже и может встать во весь рост бюрократический аппарат, да и вопросики совместимости не исключены.
>>3438184 Ныли в 2022, 2023, мб ещё немного в 2024, сейчас уже нет смысла ныть. Это как ныть что спина болит — все и так знают что у людей хуёвый позвоночник.
>>3438184 Я не могу найти 3 года опыт. Откликнулся на 7 вакансий, 1 отказ, 6 не просмотрели. Одна эйчарка сама меня нашла из сбера, сказала, что в сбере сейчас четырехэтапный собес. 1-ый базаришь с хрю, 2-ой делаешь час какой-то рефакторинг, 3-ий лайвкодинг, 4-ый техническое интервью. Я скипнул после 1-ой ступени, т.к испугался, я слаб в олимпиадном программировании, и что за рефакторинг такой, она объяснить не смогла. Ну моя проблема в том что я не откликаюсь, пока не работаю, думаю что должен изучить webFlux, т.к. это супермодно, пока не знаю зачем он нужен, если есть restTemplate и feign.
>>3437840 Чё тебе мешает работая походить по собесам, прося больше? Тем более они все в телемосте сейчас, без камер. И если нарисуется варик, свичнуться.
>>3438397 Эти велокурьеры с 200к зп с нами в одном треде? Я тебе секрет открою, но курьеры получают зп не за часы и у них нет оклада, да даже трудового нет.
Хочешь получать больше - пиздуешь крутиться и доказывать что стоишь больше велошкурьера. Пиздуешь торговать собой на рынок труда. Душишся о десятки гейткиперских собесов на сытное место, либо крутишся в потугах релокнуться туда, где лишних денег больше. Либо растешь и берешь на себя больше обязательств и ответственности, становишься незаменимым и торгуешь этой незаменимостью (тогда могут и на 60% поднять). На худой конец, переквалифицируешься в курьеры, если как ты гришь им платят больше. А пока не доказал обратное, не то что для локального кабана - для любого мимокрока-двачера ты никто и звать тебя никак, и денег своих ты не стоишь. такие дела.
А то раскатили саморефлексию блять, что аж FOMO и "от мыслей корежит". Ну сходи пополни собой коммьюнити потешных доходяг с another-it, фанфик напиши там о том, как стыдно быть программистом. Это точно повысит твои акции.
>>3438438 Ты из какого города? В ДС 100 т.р. даже на еду не хватит, не говоря уже о том чтобы снять, например, квартиру. Почему кодер должен быть полубомжом каким-то, я из простыни твоей не понял.
>>3437850 >Это в общем случае невозможно из-за проблемы остановки. 1. Аналитически задача доказательства равенства функций вполне себе решается путем преобразования или нахождения значений при который функции не эквивалентны. 2. В условиях компьютерной программы, все типы так или иначе конечны и можно просто перебрать все значения. И никакой проблемы останова тут нет, есть проблема что надо перебрать слишком много значений. Но множество всех значений функции конечно доказательство этого факта оставим читателям.
>>3434087 (OP) Перестали писать рекрутеры. Раньше регулярно получал предложения пройти собес в сбер, озон или яшку. Прилетали приглашения в линкедин и на почту с телегой. Но начиная с января этого года тишина. Почему так?
>>3438676 Айти обслуживает бизнес. Когда экономика рухнум на айтишниках это сказывается первыми. Расслабься, через пару месяцев в других отраслях начнется тоже самое. Хорошо когда у соседа корова сдохла!
>>3438590 >>Это в общем случае невозможно из-за проблемы остановки. >1. Аналитически задача доказательства равенства функций вполне себе решается путем преобразования или нахождения значений при который функции не эквивалентны. У нас машина Тьюринга. Такое решение нерелевантно. >2. В условиях компьютерной программы, все типы так или иначе конечны и можно просто перебрать все значения. И никакой проблемы останова тут нет, f(x, y) {return x+y;} g(x, y) {while(true) ; return 0; }
Докажи мне, что они не эквивалентны, не зная, что у них внутри.
>>3439189 >У нас машина Тьюринга. Такое решение нерелевантно. Дебил, блядь! Ты же не можешь дискуссию из 3-х постов уследить! Хули ты выебываешься? >>функциональный тип, как известно, одно из немногих исключений,к который в теории типов принципиально не обладает свойством эквивалентности >В теории функциональные типы прекрасно сравниваются: если для любой комбинации входных параметров, они выдают одинаковый результат, то типы эквивалентны. Теория типов - математическая теория! Там нет никакой машины Тьюринга и проблемы останова.
>>3439189 >не зная, что у них внутри. Как компилятор может не знать, что внутри функции которую он компилирует?
>>3439393 >Там нет никакой машины Тьюринга и проблемы останова. Да-да, а вот когда компилятор можно сломать комбинацией женериков, это другое, пынямать надо. Проблем при сабтайпинге ну совершенно нет, это все выдумки шарпистов.
Выпиливание финализаторов это такая тупость. "Ыыыыы из рандомного треда вызывается", как будто у нас нет огромного апи экзекуторов на любой вкус и цвет.
>>3439393 >Дебил, блядь! Ты же не можешь дискуссию из 3-х постов уследить! Хули ты выебываешься? Это ты дебил. Если ты сам отмотаешь наверх, то увидишь, что я писал про проверку на практике. Ты часто на теории типов программы пишешь?
>Как компилятор может не знать, что внутри функции которую он компилирует? О боже. Конечно в прямом виде бесконечный цикл это тривиальный случай. Суть проблемы остановки в том, что ты не можешь реализовать алгоритм, который проверит любой другой алгоритм на конечность. На любой умный компилятор найдётся ещё более хитроумный код, который он не сможет разобрать.
Как в спринге вернуть клиенту не все поля в энтити а только часть?
Вот допустим у меня есть ```java @GetMapping("/api/things") Iterable<ThingEntity> things(Pageable pageable) { return thingRepository.findAll(pageable); } ```
В ответе я вижу массив со всеми полями в БД. Как вернуть только некоторые?
>>3440723 и они называют хибернейт УДОБНЫМ. Потом ещё при маппинге будет N+1, а то и стековерфлоу
>>3440693 выкинь хибернейт, возьми простенький jdbi, из результата запроса мапь сразу в дтошку. В селекте не забудь прописать только нужные поля, чтобы не гонять все
>>3437840 А что за компания? У тебя к курсу рос рубля зп привязана или к баксу? А в каких компаниях до этого работал и как? Как кстати в рб айти сейчас? На работа бай вакансий чет мало, вообще собесов много прошел? А то я все собираюсь походить по собесам, но никак не соберусь, все лень. 1000$ наверное самый низ вилки на миддла в рб. +500$ можно смело просить на ревью. х2 от зп наверное тоже возможно, но зависит от жадности конторы, если и дадут, то со скрипом, может начнут предлагать взять еще проект на полставки или прочую хуйню ненужную.
>>3440723 >Замути DTOшку на респонз и мапь В этом весь рак джавы. Поэтому ее сейчас отовсюду выпиливают и вакансий по факту нет на рынке. Дтошки, мапперы написанные вручную, потом тесты на мапперы. Блядь, вы безнадежны. Неудивительно, что кабанам это осточертело и теперь новые проекты стартуют онли на гоулэнге
>>3441022 Те, который ты ручками пишешь. А потом на них юнит-тесты пишешь, гандон. Как же я рад, что из индустрии начали увольнять жавасуфидонов. В бигтехе теперь онли гошка или сишарп))
>>3441076 Нахуя ты оправдываешься перед этим ничтожеством? Не этой псины сутулой собачье дело что и как ты маппишь. Он пришел сюда не конструктивные диалоги вести, а за струей в ебало.
Статические методы - плоха. null - плоха. Наследование - плоха. type casting и рефлексия - плоха. Гетсеты - плоха. Паттерны singleton, DTO, Factory, ORM и MVC - плоха. Что делать чтобы было хорошо - никто не знает. Всё.
Вполне себе артефакт процедурного программирования. 256й любит говорить что ПП - это плохо, но на самом деле ПП - это вполне себе путь, хоть и довольно устаревший.
>null
По billion-dollar mistake уже кто только не прошелся. Это такой бородатый мем что я хз зачем его повторять. Наверное затем, что разрабы необучаемы и продолжают зачем то оправдывать эту дырищу в системах типов. С другой стороны, котлин немного расшевелил джавовое болото, и в последнее время разгоняется движ вокруг JSpecify, так что может не все так плохо.
>Наследование
То же. Все прошлись уже по наследованию, даже среди ООПшников есть принцип "предпочитай композицию наследованию". С другой стороны, без наследования у тебя остается довольно мало опций для сабтайпинга, так что приходится искать компромиссы.
>type casting и рефлексия
Тащемто да, в продуктовом коде им не место (за некоторыми легализованными исключениями типа этих ваших новых сопоставлений sealed иерархий через instanceof). Но та же рефлексия вполне себе приемлема в тех местах, где предметная область - это классы и их нутря. Метапрограммирование. Рефлексия в спринге, к примеру - неизбежна по определению (ну либо если без рефлексии, то через байткододроч как в dagger - мало что меняет по сути вопроса. Байткододрочу в продуктовом коде тоже не место)
>Гетсеты
Если б у меня в руках был пистолет, я ебнул бы первого кто заговорил бы со мной о гетсетах - просто до ебанутости ублюдочная по сути своей тема. Ее можно было бы конструктивно вглубь разгонять довольно глубоко, но с тупорылым взрывоопасным контингентом из взвеси ломбокодегенератов и шарпеев делать это - в дурку попасть.
>Паттерны
Паттерны - веселая штука. Прикол паттернов в том, что они работают только для конкретного языка, конкретного стиля разработки и конкретной эпохи. Меняется эпоха - меняются и паттерны.
Те же синглтоны к примеру. Никто не пишет самописные ленивые синглтоны с дабллоками. Никто не пишет даже обычные синглтоны через статические переменные или енамы. Сегодня синглтон - это тупо частный случай скоупа и жизненного цикла отдельно взятых бинов, а не паттерн.
В ФП вообще нет привычных ООП-разрабу паттернов ни в каком виде. Зато есть всякие теркат-артефакты типа функторов, аппликативов, монад, которые вполне подходят под определение "паттерн", хоть их так никто и не зовет. Короче, не стоит сильно загоняться если кто то зовет твой любимый паттерн говном - этот кто то просто сидит в другой парадигме разработки и кодит каким то другим неведомым тебе стилем, а тебя - троллит.
>>3441132 >нет тыыыы!!!!! Найс дегенерата потрясывает с того что оказалось что его стена текста которую он усердно натыкивал это просто понос из слов без единого пруфа или аргумента. "все знают", "если б был пистолет", "кто только не прошёлся", лол.
>>3441139 >щас как ещё раз насру поносом и тогда это точно аргументом станет Я не знаю. У меня нормально и наследование, и нулл работают. Может у кого-то руки кривые просто?
Что-то по делу теперь пукнешь или будешь на говно исходить?
>>3441149 Знаешь, вот если попытаться привести на ум человека что не понимает переносные значения это будет ребёнок. Дети обычно воспринимают всё буквально слишком. Пятилетний даун ты или просто умственно отсталый, не знаю, но в любом случае, для самых тупых давай без красоты речи тебе я скажу: Что сказать-то хотел?
>>3441151 Дружище, ты утверждаешь, что у тебя "нормально работает наследование". И я просто хочу посмотреть на пример нормальной иерархии в проде, где больше 100 классов хотя бы, и все наследуются друг от друга.
>>3441157 Чел, забей. Неужто ты не видишь что это порватка, которая в данный момент времени находится в тотальном отрицалове? Не тыкай говно палочкой - вонять не будет. Ему реально стоит сходить в форточку пропердеться - дай анону время.
>>3441158 Ну то есть у тебя нет наследования всё-таки? >>3441160 Ну а вдруг алмаз в куче говна найдётся, и нам принесут схему с идеальным наследованием. А то мы все врём оказывается, обманываем себя и друг друга со своими композициями.
>>3441171 Та забей, этот паарноик давно и стабильно рвонькает по одному и тому же паттерну, ничего ты там не откопаешь.
Я даже не до конца понимаю с чего он в этот раз то порвался. Я тащемто и не гнал на наследование, и изначально отметил что несмотря на принцип "composition over inheritance" тут не все однозначно. И опять шиз рвонькнул, да штош ты делать будешь.
>>3440760 Финтех, скажем так, зп не привязана к другой валюте, фиксирована в бел рублях. По вакансиям да, не густо, но на джаву штук 5 вакансий нормальных можно найти. На почту HR пару раз написали, хотя на хх у них нет вакансий. Я бы потом даже хотел в какую-нибудь российскую компанию устроиться, там и рынок и зп больше, только пока что хз как это юридически можно сделать, если я не хочу всякие СНИЛСы и ВНЖ в РФ оформлять
>>3442506 >Малышка думает, что найдет работу девопсом без опыта в сисадминстве или разработке >Малышка думает, что нейросеть не умеет писать ямлы и пердолить линукс )
>>3443304 Я сейчас сисадмин, но почему то делал упор на java(успех знакомых подстегивал) + всякие ебланы говорили что девопс в сто раз сложнее, что на самом деле не так
>>3443304 а в чем сложность пердоленья линукс с чатгпт? Все терминальное, с учетом если это опенсорм, отлично пердолится. Так же, в чем сложность чатгопоте составить ямл, если ему все нормально объяснить че-куда?
>>3443305 Ааа, ну тогда ты реально всрал полтора года на хуйню без негатива. Тебе осталось буквально изменить название резюме на девопса и развернуть локально гитлаб, куб, стек для мониторинга и прочие баззворды из вакансий. Поковыряться в этом на выходных и спамить резюме везде. Хуй знает зачем ты вообще связался с джавой, а не питоном/го которые в 10000 раз полезнее для девопса. Я если что мимо пхпшник который пытается влезть в джаву, но из-за сокращений джавистов зимой план пошел по пизде.
>>3443310 Спасибо за мнение, тут уже психологический фактор, что сложновато будет слезть с джавы, на которую я дал себе установку она или смерть нахуй, так как была еще маленькая надежда что знакомые к себе могут взять, хотя об этом никто и не говорил, но пошедший по пизде рынок трудоустройства заставил задуматься что я мудак. План был, да и есть, все таки допердолиться до собеса (с волчьей помощью) и после жестких попусков, уже со спокойной душой , выгоревшем нахуй нутром полностью кинуть все силы на девопс
>>3443305 >что на самом деле не так Чет не очень верится, там же куча подводных типа всяких юидов юзеров, сигроупс, маразматических расположений конфегов в etc, и системд еще логи читать и чинить хуй пойми что. Ну и зависимости чинить... Вот когда-то давно ебался с тем, что мне надо было подтянуть gtk+ в lsp и сборку, а дистрибутив особенный и не позволяет это так просто сделать, поэтому нужно создавать что-то вроде отдельной развертки с собственным PATH, щитай недоконтейнер, ебань еще та и что самое грустное, в других дистрах ебань была бы вероятно еще больше. Ну или вот из совсем недавнего, мне блять подсунули сборку на мавене, где в процессе она качает ебаный бинарник в линукс. Не знаю, какому гению пришла в голову такая светлая идея, но мне че, пришлось ручками декомпилить вызовы dynamic lynk, чтобы персвязать все это добро нормальным образом. Для меня это какая-то ну лютая дрочка, может поэтому и кажется, что это гораздо сложнее чем просто писать кодек в идешке.
Вкатываюсь в джаву
Вкатунидзе30/04/25 Срд 15:41:32№3443600224
Сап, учу джаву уже около 2 месяцев, изучил кор более менее(много не знаю еще, но думаю по мере изучения закрою темы, которые не знал). Сейчас попердолил сервлеты и тыкаю хибернейт. В мае начну спринг. Как у вас дела?
>>3443630 Чтобы @Query нормально писать, репозитории генерить. Иначе че там, придется самому EntityManager распихивать, каждый метод расписывать. Еще не дай боже, вообще Criteria API использовать. Просто ужс. Впрочем учитывая то, что он легко переписал с jdbc там наверное что-то уровня CrudRepository.
>>3443649 google, youtube, фантазия в голове когда пишу что-то В основном смотрю технологию, повторяю за индусом, потом сижу сам пишу, а так читал Эккеля когда кор учил, хорошая книга
Посоветуйте лучший способ изучить Spring Boot, если я уже знаю Java, давно на ней пишу но ванильно, без фреймворков. Но при этом знаю веб фреймворки Джанго для питона и Ларавел для ПХП. Для веба делаю проекты только на Джанге и Ларе.
Но сейчас мне нужно будет делать проекты на Java тоже и я не хочу это делать на велосипедах, точнее это ваще не варик, такую работу не примут. Хочу делать на Spring Boot но не знаю как его лучше изучить, чтобы без лишней хуйни, коротко и по делу что куда.
Мда, теперь понятно почему вакансий стало так мало, особенно нормальных. >Во время беседы с главой Meta* Марком Цукербергом на конференции LlamaCon глава Microsoft рассказал, что ИИ пишет 20-30% кода в репозиториях компании, а «некоторые проекты, вероятно, полностью написаны» нейросетями. Он добавил, что этот объём «неуклонно растёт». По наблюдениям Наделлы, ИИ лучше справляется с Python, чем с C++. >В конце апреля 2025 года во время отчёта о доходах гендиректор Google Сундар Пичаи заявил, что ИИ пишет более 30% кода для компании. В 2024-м он сообщал о четверти сгенерированного кода.
>>3444097 Факт, тоже так считаю, что все кто говорят о замене рабочих мест и о том что скоро ии будет работать за всех имеют прямое или через 1 руку отношение к ии и их капитал от этих слов увеличивается соответственно
Как дела у вас? Не пишу ничего 2 дня. Уехал в архыз на отдых. Первую строчку кода в мае напишу только в воскресенье
>>3445045 Останутся спецы высококвалифицированные\сеньорного плана, они будут настраивать ии, чтобы те делали мидловые\джуновские задачи, уже ведь такое практикуются
>>3443803 Если времени много, то лучше учить с обычного спринга, где бины в xml файлах описываются. В спринг буте прям очень много магии по сравнению с ванильной джавой и он будет восприниматься как новый язык и глубокого понимания не будет. Для меня лучший способ учить всякие фреймворки - это видосы, где кто-то пишет с нуля полное приложение, постепенно добавляя фичи. Смотрю видос и пишу код параллельно с автором, останавливаясь, чтобы что-то обдумать, понять. Так понимаешь вообще как мыслить в рамках нового фреймворка, с чего начинать и как вообще все запустить. На ютубе была серия видосов, где автор писал аналог твиттера. Можно еще поискать какие-то сливы курсов по спрингу с юдеми на рутрекере.
>>3446049 Ещё бы обычным разработчикам всю эту магию давали. А то как будто луа скрипты для игры "джава" пишем. А точно, если дать то нельзя будет больше кривляться "а надо было медленный бойлерплейт писать, ишь чё удумал решать задачи крупнее laba1, не было бы поломок обратной совместимости)))))".
>>3446051 >As @Stable annotation is applicable only to internal JDK code, you cannot use it directly in your Java applications. However, we are working on a new JEP called JEP 502: Stable Values (Preview) that will provide constructs that allow user code to indirectly benefit from @Stable fields in a similar way.
>>3446181 Если ты в совсем мухосранске то лучше ракать пхп, особенно сейчас во время кризиса. Либо переезжать в дс. Даже ката академия при подготовке волков форсит их перебраться в столицу.
Блд-шиз, ты там умер? Беспокоюсь за тебя. Живо подорвался кабанчиком пояснить почему bld говно и aint gonna boom, потому что я всё больше уверен в обратном.
>>3446417 Автором того поста был не я, но я отвечу. Нет смысла от таких вопросов, потому что почти всё одинаковое по задачам, по деньгам и тд. Различия где то там в глубине, но это не то о чём надо думать при выборе.
Лично я выбрал Джаву, потому что мне хочется работать в крупной компании, на крупном проекте, с большим кол-вом людей. Плюс как то я пробовал писать на PHP+Laravel и меня прям воротит от нетипизированных языков. Вот хуй знает почему, просто их как то для себя лично не уважаю, не нравятся мне. + Джава, потому что я не люблю продукты майкрософт, их дизайн код и тд - не моё просто. Go - ваще хуй знает что это и нахуя, там какое то специфичное для нашиъ дней написание кода (вроде функциональное программирование, а не ООП - но это не точно) + слышал что на этот язык берут опытных людей, для которых это не первый язык и есть коммерческий опыт в неколько лет на чём-то другом. Да и просто нет интереса к этому.
Подытожив, становится понятно, что тут деньги или спрос на язык не влияют никакой роли, язык выбирался чисто по своим позывам души
>>3446451 мы говорим про ВКАТ именно, парень на первую работу идёт вот и интересно, он же молодой находчивый, почему не го? >мне хочется работать в крупной компании, на крупном проекте, респект
>>3446195 Ну я с завода перекатился в сишарп отчёты в госуху, но там вообще не бэк, пишу шаблоны к отчёту на шарпе и базу тыкаю. А так на хх есть госуха с джавой и частные корпы ищут, но там от года ну и стэк нужен
>>3447321 Мне кажется если будет еще один карантин произойдет точно такое же, а так да двачую чела, все как в 2020, людей просто больше на вакансию, но волки не спят
>>3447604 Ничего резкого. Одно плато длится уже раз в 10 больше чем весь тот ковидный спад вместе с падением, минимумом и восстановлением до доковидного уровня.
>>3448279 я не аналитик, но думаю что это как крипта или акции - попадало всё. Просто компаниям столько теперь не надо, для мелкой хуйни используют ИИ, челы попродвинутей, коих меньше, пробиваются на имеющиеся позиции
>>3448279 Просто обычно думают что джун приходит, сначала просто какие то ошибочки исправляет, даже не всегда фреймворк юзает. А теперь эта потребность закрыта и надо приходить сразу готовым
Поломка обратной совместимости это так тупо. Имаджинируйте её не в языке программирования, а в натуральном языке:
>20 МАЯ 2025 ГОДА ВЫХОДИТ РУССКИЙ ЯЗЫК 7.23 В КОТОРОМ УДАЛЕНА ПОДДЕРЖКА ПРИЧАСТИЙ ПРОШЛОГО ВРЕМЕНИ ИЗ-ЗА СЛОЖНОСТИ ПОДДЕРЖКИ, ЗАМЕНЫ НЕТ, ПИЗДУЙТЕ МИГРИРОВАТЬ ВСЕ СТАРЫЕ КНИГИ НА НОВУЮ ВЕРСИЮ ЯЗЫКА
А, теперь мне понятно, почему новый Ворд стал настолько медленным, что специально для него включили жадную загрузку в память вместе со стартом винды сука.
Есть живой враппер какого-нибудь 3д говна на джаву, типа JOGL, только чтоб под java 21 хотя бы запускался? Я заебался уже перебирать примеры с jogl, там нихуя не работает без костылей
Мужики! Я, конечно, понимаю, что у каждого из вас тут есть претензии к джаве, идеи как всё сделать лучше и вообще - плох тот солдат, кто не мечтает стать генералом. Но просто поймите: в Oracle же не дураки сидят! Там, я думаю, и без вас разберутся, что добавлять, а что нет. И потом, если каждого так послушать, одному это дай, второму то добавь, третий говорит всё убрать. И что? Что по вашему тогда должно делать начальство в Oracle, чтобы все были тут довольны? К чему это всё приведет? Раз все такие умные, делайте сами свой язык тогда. Я лучше буду сидеть тихо: пусть как начальство скажет, так пусть и будет. А то советчиков полон тред, а я напомню, что пиздеть - это не мешки ворочать. Я всё сказал. Хватит ныть и ругать начальство!
Я правильно понимаю, что выучив жабу я с 80% вероятностью буду поддерживать легаси 11-х, 17-х и 8-х версий? И я правильно понимаю, что выучив голанг, я с 80% вероятностью не найду работу ждуном? Всё правильно понял?
>>3449194 А ты расист штоле, говно правое? СКАЖЕШЬ ЭТУ ХУЙНЮ В ЛИЦО ВСЕЙ СЕМЬЕ ВСЕМ ПАНКАМ АНТИФА! ТОЛЬКО МОЛОДОСТЬ, ТОЛЬКО МЫТИЩИ, ТОЛЬКО ХАРДКОР! ВПЕРЁД ЮНИТИ! 359!
>>3449824 С чего такие мысли? В бигтех набирают стажеров, ждунов. Двое знакомых собесились в яндекс, тбанк. Обоих прошляпили правда, сказали мало проектов, но мб если проектики попилить, то возьмут
Меня просто воротит от мысли, смотреть и писать джава код, он такой МНОГОСЛОВНЫЙ, я просто в ахуях сижу. А голанг такой минимальный, строгий, ахуенный язычок. Ээййхх
>>3449827 >В бигтех набирают стажеров, ждунов Бля а сколько у нас в стране населения? То что там какой-то сбер, озон, т-банк, ещё кто-то опубликовал тысячу другую вакансий - это пшик, капля в море. В пересчёте на весь рынок, это будет какой-нибудь 0,1%. Грубо говоря 1 стажёр на 999 обычных вакансий. Попасть можно, но непрактично на этом строить будущие планы.
>>3449922 А какие ещё проблемы для макакена, должны быть? Мне как-то типок задвигал, что контейнер с жаба микросервисом весит 20 гигабайт. И, мол, учи голанг, ведь жаба медленная и хуйня вообще. Должно ли меня это ебать? Заказчик сказал сделать - я сделал, если он просит, значит надо. А для макакичей только такие проблемы и будут, что синтаксис хуйня или вакансий мало. Я в своё время так отказался от плюсов, ибо того рот ебал трижды читать и разбираться в С++ проектах, это бля такая хтонь
>>3449940 Много запутанного говнокода вперемешку с корпоративными велосипедами и интеграциями с хуйней без документации. Если на проекту поработало несколько человек - сидишь как археолог разгребаешь где тут важный костыль, где говнокод от джуна, а где очередной модный паттерн от шизосеньора. Иногда только по блейму догадаться можно. И тебе нужно не просто разобраться, а встроить туда свой кусок говнокода, чтоб все не развалилось к хуям. Особенно когда тестов нет и ты узнаешь что что то наебнулось от тестера или девопса. спасибо что не на проде, но и такое бывает
>>Я в своё время так отказался от плюсов, ибо того рот ебал трижды читать и разбираться в С++ проектах, это бля такая хтонь Ну тогда добро пожаловать. Снова.
>>3449827 >в бигтех набирают стажеров, ждунов Кстати, а зачем они этой хуйней занимаются? Типа чтобы никто не подумал, что в компании проблемы с финансами? Типа у них денег дохуя, можем позволить даже стажеров брать, учить их чему-нибудь? Или наоборот из-за того, что нет денег и дешевле взять студентика? Какая им выгода от этого, если сейчас айтишников наоборот на мороз выкидывают? Зачем учить новых долбоёбов, если за забором и так очередь из сенек, которые всё никак не могут найти работку?
>>3450000 Там бабки крутятся немыслимые. 300к за все 3 месяца стажера отдать, при условии, что он может остаться, они могут, даже если он уйдёт - похуй, это для них пыль.
>>3450000 >Зачем учить новых долбоёбов, если за забором и так очередь из сенек, которые всё никак не могут найти работку
Много сенек с докрученным опытом. Много просто лоускилльных сенек. У нас пару месяцев назад такого наняли. По грейду сеньор, лет 10 опыта в айтихе на разных проектах. А по навыкам что-то между джуном и мидлом, у нас некоторые джуны код лучше него пишут. Опять же, каких-то гигантских сокращений на айти рынке не было, толпы сенек за забором сами по себе не могли образоваться. Приток сенек идет во многом из-за людей с фейковыми резюме.
И в этом смысле лучше взять стажера на стажерскую зарплату и срочный трудовой контракт, чем вкладываться в мутного мидла или сеньку, нанимая его сразу на бессрочный контракт и на большие суммы. Если стажер не перформит (например просто потому что овощ или в универе загруз большой и не получается совмещать), то стажер просто уходит на мороз через 3 месяца без лишних проволочек. В случае с мидлосенькой его придется внимательно оценивать на испыталке и в случае увольнения расходы будут сильно больше.
>>3449824 Вообще я не думаю, что стоит делать перекат golang -> java, на российском рынке сейчас лучше гоуленг доучить и пойти стажером куда-нибудь в yadro/озон/wb, с джавой компаний не сильно больше нынче и стажеров нанимают в основном только в бигтехе. На хх.ру искать работу стало бесполезно, по моим ощущениям. Как будто херки больше не считают его хорошим инструментом для поиска кандидатов, и если есть открытая позиция, то через нетворкинг и рефералки пытаются находить людей.
>>3449978 Да как будто такое везде есть. Про запутанный говнокод ты ещё плюсы не видел в проде. Двойная ссылка это стандарт, тройная - повсеместный костыль, которые не меняют ГОДАМИ, переменная UF_GH_TR6LK = 0000HASHCOPORNx47, что это никто не ебёт, шизосиньор скинул в папочку, ты её импортнул, так надо, 80% библиотек - эксклюзивчик компании, поэтому весь твой опыт котируется с меньшим энтузиазмом, если ты переходишь в другую компанию на ТОТ ЖЕ СТЕК, миллиард типов, громадные методы, классы и того больше, всё разбито на хедеры и исполняемые, притом в хедерах бывает и реализация, ну а хуле, зачем выносить в отдельный файл.
>>3449942 >Всмысле стране? Я про дс говорю. Ща бы искать работу в айтишичке не в дс 1/2 Попасть на стажировку - это всё равно что поступить на бюджет в МГИМО. Туда поступают те у кого 90+ баллов по каждому предмету и конкуренция 50-70 человек на место. Без разницы - москва не москва, джуниорские вакансии - это всегда 1% всех вакансий. На всех языках и на всех стеках. А стажировок в 10 раз меньше джуниоровских вакансий, отсюда и 0,1%.
>>3450066 >И в этом смысле лучше взять стажера на стажерскую зарплату и срочный трудовой контракт, чем вкладываться в мутного мидла или сеньку, нанимая его сразу на бессрочный контракт и на большие суммы
Бля, я буквально те же выводы транслировал своим шизам-манагерам, когда те ринулись хайрить людей, но куда там... нахайрили каких то долбоебов, а мне возись с ними теперь...
>JEP 512: Compact Source Files and Instance Main Methods >The static methods of the IO class are no longer implicitly imported into compact source files. Thus invocations of these methods must name the class, e.g., IO.println("Hello, world!"), unless the methods are explicitly imported. Блядь, какие же дегенераты. STR."\{zalupa}", IO.println("pizda"), когда ж эти дауны уже успокоятся-то.
>>3450831 А что не так? Ниже в том же жепе написано, зачем так сделоли: >In earlier previews of this feature, we explored the possibility of compact source files automatically importing the static methods of the new IO class. Thus developers could write println(...) in compact source files instead of IO.println(...).
>This had the pleasing effect of making the methods in IO appear to be built-in to the Java language, but it added a speed bump to the on-ramp: To evolve a compact source file into an ordinary source file, a beginner would have to add a static import declaration — another advanced concept. This runs contrary to our second goal, namely that that beginners should be able to grow their code gracefully. This design would also create a long-term burden of reviewing a likely endless stream of proposals to add additional methods to the IO class.
Понимаю, самое хуёвое когда к тебе приходит чел лет 30-50, который самый умный, всё знает и его не надо учить. На любые предложения использовать более современные инструменты огрызается или говорит ладно ПОСМОТРИМ и продолжает писать код в NetBeans или в vim-е. И не пользуется нейронками, ГУГЛИТ.
>>3451784 Было бы мне глубоко не похуй на их методы. Перформит - и то ладно. Иронично то, что нахайрили как раз таки великовозрастных долбоебов под нейронками. Ожидалось, что они будут брать на себя отдельные направления развития софта - сеньки же. А по факту - оказалось что это лысеющие анальники, которые встают в ступор от любой ошибки билда, на которую их нейронка не дает внятного анамнеза. И ладно бы если б они просто бежали с вопросами ко мне - не жалко. Волпросы от них звучат как "бля, чето не билдится - в чем может быть причина". Допинфу и логи приходится клещами выдирать.
Вот как так получается что с нейронкой они значит готовы раскидать промт со всем тщением и дотошностью, а с людьми уровень софтскиллов - как у валенка ебаного? Колмплексы какие то - не иначе...
>>3450383 Да я просто за эти выходные обчитался МВП треда, другое-ит, новостей и видосов что ойти в с ё. Теперь пытаюсь найти для себя причины продолжать дальше вкатываться. Если раньше казалось, что если в любом деле ты реально шаришь, то всегда что-нибудь найдешь. Сейчас, мне кажется, для айти это уже не актуально. Я на предпоследней стадии принятия.
Чел - "другое айти" это сборище клоунов на кризисе среднего возраста. Посыл их высера в целом может изначально и правильный (что айтишка перехайплена говновозами на инфоцыганах с целью прогрева лохов), но они сами не заметили, как выродились просто в банду ЧСВ-нитакусиков. Воспринимать их всерьез - себя не уважать. Даже их предтечи-хохлы со своим ebanoe.it выглядели солиднее: хоть и там тоже чувствовался этот рак, у них хотя бы были мемы про те же сыры за 500 гривен.
Клоуны уже даже не стараются как раньше освещать уебищные кейсы и кадры айтишки - сидят и фикшн-фанфики только строчат. Менталитет неудачника во всей красе.
>>3451945 Может ты и прав, но я как то все равно больше симпатизирую студентоте. При должном менторстве из студентоты есть шанс вырастить специалиста. Из зазнавшегося лоускилльного сеньки - никогда. Но я понимаю твой скепсис в отношении зумеров: почитаешь вкатунов - чем они мотивированы, что ими движет, как они рассуждают - и понимаешь что будущего нет и времена "горящих глаз" прошли.
1) В dto не должно быть логики 2) Наследование - плохо. Максимум 1 уровень 3) методы в виде чистых функции - хорошо. Легко тестировать, легко применять, не имеют сайд-эффектов 4) Сайд-эффекты - плохо 5) Логика - в Service или Utils 6) метод очень желательно в высоту не более 1 экрана (90 строк) и не более 7 параметров 7) Максимум 3 уровня вложенности в условиях 8) Если код повторяется 2 раза - вынеси в функцию 9) Не применять теги ломбока: Data - опасно из-за equals и toString и вложенных объектов 10) методы называть глаголами, переменные существительными или прилагательными
>3) методы в виде чистых функции - хорошо. Легко тестировать, легко применять, не имеют сайд-эффектов >4) Сайд-эффекты - плохо
СУБД для тебя - шутка чтоли? Один сплошной сайд-эффект, считай... Короче, если у тебя на руках нет референса для подражания, эдакой петклиник в ФПшном reference-transparent стиле, готовься быть непонятым и посланным нахуй своими коллегами-долбоебами.
>5) Логика - в Service или Utils
Допустим
>6) метод очень желательно в высоту не более 1 экрана (90 строк) и не более 7 параметров
Я б не доебывался до количества параметров
>7) Максимум 3 уровня вложенности в условиях
Многовато, но хуй с ним...
>8) Если код повторяется 2 раза - вынеси в функцию
Опасная риторика. Можешь в итоге обнаружить себя посреди леса функций, делающих хуй пойми что, и именованных также.
>9) Не применять теги ломбока: Data - опасно из-за equals и toString и вложенных объектов
Я бы в целом выпилил лобок, но ок, допустим
>10) методы называть глаголами, переменные существительными или прилагательными
>>3452112 >Хочу создать манифест на работе Гиблое дело. Особенно, если в команде больше 3 разработчиков. В принципе старайся ничего не улучшать и не предлагать. Дали задачу - сиди и делай. Сделал? Бери следующую задачу. Это дело неблагодарное и тебя никто не похвалит. Либо все кивнут, мол "да-да, давайте так делать" и хуй забьют
>>3451754 @echo off NET SESSION >nul 2>&1 IF %errorLevel% NEQ 0 ( echo This script requires administrator privileges. echo Please right-click on the script and select "Run as administrator" pause exit /B 1 )
SETLOCAL REM Only remove specific evaluation-related files IF EXIST "%APPDATA%\JetBrains" ( del "%APPDATA%\JetBrains\PermanentUserId" del "%APPDATA%\JetBrains\PermanentDeviceId" del "%APPDATA%\JetBrains\\.key" del "%APPDATA%\JetBrains\\.license" del "%APPDATA%\JetBrains\\bl" del "%APPDATA%\JetBrains\\crl" )
REM Clear JavaSoft registry entries REG DELETE "HKEY_CURRENT_USER\Software\JavaSoft" /f
>>3451761 >OpenIDE >исходники закрыты Да наши как я вижу уже научились брать пример с уважаемых партнёров OpenAI, FreeFileSync, "open hearted open sourced" httpie, список бесконечен.
>>3452620 Я пишу на FASM библиотеки и подключаю их к жабе через JNI. Довольно увлекательное занятие. Кресты не знаю, слишком сложно, там один Boost больше всего Spring'а. Для системного программирования достаточно сишки и ассемблера.
Где вы работаете? Откликнулся на hh.ru на все удаленные вакансии со словом Java и везде получил отказ. Сейчас знакомый взял виндовым админом за 12 тыщ.
ВСем привет, у меня тут препод в соседнем треде спрашивает >>3453031 → >Ну окей, блиц ответ без IDE, что будет если есть иерерахия Animal и Cat extends Animal, и в ней статик-член whoAmI, равный "animal!" и "cat" соответственно. >Ты делаешь вот так: >Animal cat = new Cat ("Ya dolboyob!"); >System.out.print(cat.whoAmI); >Что выведтся и почему? чё ему ответить?? Помогайте, а то он от меня не отстанет
>>3453056 Прикольно. Как это работает? Он типа компилит классы прямо из строкового представления и тут же их загружает в реальном времени? Это виндовс?
Как вкатиться на архитектора? Работал сеньором, пару раз проходил систем дизайн, что-то читал, смотрел многие доклады на эту тему, вроде начальное понимание имеется.
>>3453187 Тут просто о том, что статический член нельзя override, его можно только скрыть (hide). Короче если ты у переменной супертипа дергнешь статик-член, то вызовется член именно переменной, а не фактического объекта, но который она указывает. Подъебка в том что нормальные люди никогда не зовут статик члены через инстанс (хотя синтаксически так и можно), за это надо пиздить. Правильный вызов был бы Animal.whoAmI или Cat.whoAmI, и тогда нет никакого скрытого трика во всем этом.
>>3453205 А почему нет? На уровне байткода поля и методы - кардинально разные концепции.
Чтение статического поля - это getstatic, чтение обычного поля - aload(objectref). В обоих случах опкод ждет на верхушке стека однозначный вполне себе статичный сет операнд. Скорее всего если мы скомпилим пример и посмотрим байткод, там буквально в месте где читается whoAmI будет `invokestatic Animal.whoAmI`. И похуй на переменную, похуй на тип обьекта на который она ссылается.
Для вызова методов же там целая палитра из invokов.
>>3453412 О, точно! Помню-помню такое. Еще вроде бы был maven-beanshell-plugin, через который можно было прям из помника подлезть во внутренние структуры мавена и буквально наскриптовать себе недостающий goal на нем.
>>3453387 Ну, джаве так-то недалеко до этого, тут скорее вопрос за инструментарием. Оптимизировать мавен архетип, чтобы не выполнялся три года, вся хуйня.
>>3453855 Если с нуля будешь что-то педалить, и будешь являться ньюфагом. Я например на прошлой работе заебенил софтинку которая напрямую общалась с БД на лоу-лвл JDBC слое. Там просто был ёбаный завод и IT работало по принципу кто во что горазд. Даже чуток стыдно за тот кринж, там даже нет защиты от инъекций через Prepared Statements (хотя это просто БД всякого мусора без sensitive data, но все равно зашквар). То есть если какой-то бедолага когда-то доберется до этого куска кала, то для него это и будет случай "может и редко, но иногда".
>>3453855 Так Jooq считай сам по себе тонюсенькая прослойка вокруг raw sql, на фоне жирных ОРМов он скрывает минимум. Ты имел ввиду raw jdbc может быть?
С jdbc нужен скилл. Выстрелить себе в колено там как нефиг делать.
>>3454242 У тебя есть слои: Внешний мир - Контроллер - Сервис - Репозиторий. На каждом уровне ездят свои данные. Dto передается между сервисом и репозиторием, это литерали строки из sql, которые отмапили в классы для удобства. Между контроллером и сервисом передается Model, она может совпадать с дто, а может и нет. Между внешним миром и контроллером передается Payload, его называют по схеме XxxRequestPayload и XxxResponsePayload, слово payload часто опускают: GetUserRequest -> GetUserResponse. Почему нельзя просто взять DTO и прокинуть от контроллера до бд через орм - а потому что китайский хакер тебе туда насует говна и поменяет те поля, которые менять нельзя.
>>3454410 Предположим, у тебя есть юзер с полями Name строка и Status число. Есть ручка UpdateUserName. В ручку приехал какой-то джейсон, ты его отмапил на дто, положил эту дто в бд, все ок. Но, есть нюанс. Хакер передал в джейсоне не только name, но и status, орм его подхватил и тоже изменил, хотя это делать нельзя. В пейлоаде же у тебя будет только поле Name и только его ты скопируешь в DTO.
>>3454424 > имплаинг в любое очко не всунут TLS/SSL, и кроме ...lfkve984hoedqfj9./.-3xlx0... узкоглазый китайский школьник ничего не увидит
Так а что помешает в пейлоад запихать имитацию того что там есть статус? Чем принципиально отличается json от пейлоада, если и у того и того спецификация какая-то более менее открытая? Пейлоад это что, не какой-то текст? Я сириусли не понимаю как такие детсадовские меры могут защитить канал сильнее. Да даже если там сериализованный бинарный поток передается, это энивей не шифр, тот у кого хватит мозгов раскрыть канал уж такую-то хуйню точно расшифрует. Тем более на стороне СУБД придется пилить сервис-десериализатор. Или я дебил?
>>3454452 Я нихуя не понял Ты можешь в паре слов описать где какие программные компоненты, протоколы и какова сущность уязвимости, которую ты там описал? я хоть усрись не могу понять, как у тебя внутрь физического сетевого канала между сервисом и СУБД попадет что-то, что не является "носителем" jdbc-протокола? Все эти геберы-хуиберы, дто, залу-пэ-о и прочие фантики существуют только на уровне java-сервера. В сеть это все уплывает энивей как jdbc-траффик (и защищен он через TLS, если админят все это не дебилы, что гарантирует его защиту если не проебаны сертификаты db-сервера). Как этот мамкин хакер что-то там заэксплойтит внутри этих dto и json? Снимет дамп JVM и что-то там заижектит? Но если у тебя JVM куда-то утек, то ебаный "статус" в DTO - твоя самая маленькая проблема. или я что-то неправильно понимаю? Нет, можно на строне DB-сервера поднять свой java-сервер, который будет обслуживать запросы с app-сервера, и между ними поднять хоть охуеть-надежный-не-имеет-аналогов-протокол, А сам этот сервер будет ходить на БД по локалхосту. И все это можно окукулить файрволом. Только как-то непонятно целеполагание для сооружения такой хуйни, если старый-добрый TLS надежен абсолютно, если только админы не долбоебы, которые хранят сертификаты в pem формате прямо под носом у всего домена на 20к человек с 777 правами.
Допустим у тебя на сайте есть пользователи У этих пользователей есть профили Пользователь может зайти в свои настройки и поменять там Имя, Почту, День рождения и т.д. Все эти данные передаются в форме POST запросом с клиента на сервер Названия переменных POST запроса совпадают с полями сущности User в БД У тебя стоит валидация на эти поля Тебе прилетает POST запрос Ты радостно валидируешь ВСЕ поля которые к тебе пришли Ошибок нет Ты эти поля записываешь объект User автоматически Сохраняешь изменения
Теперь твой пользователь стал админом, потому что подменил поле isAdmin с 0 на 1
Этого поля не было в форме на сайте в редактировании профиля Но кто тебе сказал что POST запрос тебе придёт точно с теми же полями что у тебя в форме? Я могу руками создать этот запрос и написать туда любые поля в том числе и isAdmin
>>3454485 эммм.... изначально ты написал литералли это: >нельзя просто взять DTO и прокинуть от контроллера до бд через орм - а потому что китайский хакер тебе туда насует говна и поменяет те поля, которые менять нельзя Но это вообще другая сторона относительно фронта, это как бэк общается с БД. При чем тут формочки которые с сайтика таскаются? И даже если так, то в чем твое решение? Если это http как в непуганные 90-е, что тебе помешает насрать в тот же самый пейлоад? Особенно если то что ты называл изначально "пейлоад", как я кажется начинаю понимать, это литералли пейлоад http-протокола, который, внезапно, в 95% случаев, omg, и есть json! Короче, ЯННП. А может ты. А может уже и похуй. Это я все к тому что все эти абстракции внутри бэка нужны чтоб посильнее изолировать горе-джуна от страшного лоу-лвл программирования, а не для безопасности. Безопасность обеспечивается безопасными сетевыми протоколами.
>>3454496 все понятно. Если б ты в первом же посте не сказал что тут имеет место какое-то "прокидывание говна от сервиса в БД", то я бы не уплыл от сосредоточении на том что идея в том чтоб сервер помнил, что именно он ждет в ответе, и фильтровал мусор. Хотя это довольно очевидно. я на самом деле больше админю, а тут сижу по фану, не ебу архитектору спрингового всего этого барахла
>>3454516 >mass assignment Прикольно, не знал, как это называется. Суть в том, что перекладывание из request в model, из model в dto - это такая защита от дурака. Простое и надежное решение.
>>3454391 >Dto передается между сервисом и репозиторием Эммм.... нет, чел.... Сразу видно, что ты залетуха. Дто в контроллере мапится на модель, а дальше передается в сервис. Там он сохраняется в репозитории. Не нужно городить какие-то "дто между сервисом и репозиторием". Посмотри выступления Борисова, чел...
>>3454639 у меня дто заполняется в ждбс маппинге. Зачем плодить сущности и мапперы? И берёт из бд только то что нужно, не больше не меньше, без Н+1 запросов
>>3454646 Ты не шаришь в клин аркитэкча, чел.. Контроллер вызывает маппер, который конвертирует дтоху в модель, а затем передает ее в сервисный слой. Сервисный слой потом выплевывает другую модель, которую ты конвертируешь в контроллере и отдаешь клиенту. Читай Анкл Бэба, чтобы не быть бэттхёртом, чел...
>>3454639 > Дто в контроллере мапится на модель, а дальше передается в сервис вот у меня так сделано, только мапинг происходит в сервисе, а не в контроллере разве маппингом не должен заниматься слой сервиса?
Да и без клин архитекчи понятно что наша логика не должна работать с запросами, которые могут менятся и могут быть разными и что наша логика начинается за границами контроллера, а значит именно контроллер должен попросить кого-то создать из запроса дто, потому что именно в контроллер прилетает запрос и он служит границей, по одну сторону которого внешний мир, а по другую наша отстёгиваемая бизнес модель
>>3454703 >разве маппингом не должен заниматься слой сервиса? Слой сервиса может использоваться как зависимость в других сервисах. Это ок в жабе, когда у тебя сервисный класс ЮзерСервисИмпл зависит от 7-10 других сервисов, а те от других сервисов и т.д. Плюс вся работа с базой там же и все сайдэффекты и прочие хуитки там же. Это жаба-вэй
>>3454809 почему? из его поста я примерно понял, что сервису лучше прнимать модель, а не принимать дто и мапить в других сервисах, которые использют этот сервис, может не оказаться этого дто, а иметься сразу модель тащить за собой мапер нафик надо кратко - сервисы должны работать с уже готовыми моделями, а не заниматься хуйнёй яеблан и не понял или как?
>>3454833 >сервисы должны работать с уже готовыми моделями Я одного не понимаю, как вы эти ебаные модели вообще достанете на уровне контроллера? Модель, конкрентно в хибере - это @Entity, которая сидит в бакете. Тебе придется обратится к бд, для того, чтобы её достать. Причем при переходах между сервисами эти энтити могут терять свою свзяь с бакетами(=пошел нахуй при обращении к Lazy или коллекциям), а какие-нибудь неосторожные сеты вообще могут изменить значения.
>>3454886 Ну т.е. есть дто уровня апи, которое маппится в json, есть dto уровня сервисов, которое абстрагируется от @Entity и это зовется "моделью", и есть энтити, то что сопаставляется с бд? Модель уровня репозитория, причем на уровне репозитория тоже есть DTO, которые например объединяют пару энтити. И вот скажем, чтобы изменить поле в какой-то энитити, нам сначала приходит дто уровня апи, которая маппится в "модель" и отдается сервису. Сервис обращается к репозиторию и достает энтити в ней шаманит и на выходе опять же отдает "модель", а не энтитю. Потом эта "модель" маппится в обратно порядке в дто уровня апи, а потом json. Client Layer (JSON) │ ↑ ↓ │ Controller Layer (Accepts/Returns "API DTOs") │ ↑ ↓ │ Service Layer (Uses "Service DTOs" or Domain Models) │ ↑ ↓ │ Repository Layer (Works with JPA Entities) │ ↑ ↓ │ Database Layer (SQL)
И между сервисами гуляют не энтити, а дтошки своего рода. Я все правильно понял?
>>3454899 У тебя в контроллер прилетает UserDto на создание пользователя. Ты прямо в контроллере мапишь UserDto на User и передаешь его в сервис UserServiceImpl. Тот уже вызывает UserRepository и сохраняет в базу, возвращая User с заполненным id, например. Затем ты возвращаешь User из UserServiceImpl в контроллер и там мапишь в UserDto и отдаешь клиенту. Это прямо самый простой кейс. Если тебе приходит просто строковый айдишник в контроллере на GET вызов, то ты его просто передаешь в сервис UserServiceIMPL и там через UserRepository достаешь нужный User из базы. Проблемы начинаются, когда у тебя появляется чуть более сложная логика - связь с другими сервисами, необходимость пукать в кафку, отправлять письма, обращаться в другие системы по REST/gRPC. Т.к. все сайдэффекты у тебя в сервисном слое, то ты его хуй протестишь кроме гнойных и ублюдочных сраных "тестов" на моках либо тормозном говнище в виде интеграционных тестов, блядь. В этом рак сраной жабы
>>3454917 Контроллер не сможет смаппить UserDto в User, если User это @Entity, например потому, что в бд ID суррогатный, а не натуральный и его банально не существует в апи. Поэтому я и говорю, что у если у вас на уровне сервисов именно энтити в качестве аргументов, то это хуйня по многим причинам, которые писал выше. Если это не энтитя, то метод save jparepository очевидно не будет работать. Ещё Impl не обязательно, спринт же умеет инъектить и классы.
И что ты имеешь против моков? Есть пример где подобное решено лучшим способом?
>>3454933 >Контроллер не сможет смаппить UserDto в User, если User это @Entity, например потому, что в бд ID суррогатный Он и не должен его мапить. Ты же создаешь пользователя, а значит твой UserDto не содержит поля id. Оно появится уже после сохранения сущности в базу. По факту у тебя CreateUserDto -> User -> DB. И обратно у тебя уже юзер с id DB -> User (id) -> UserDto
>И что ты имеешь против моков? Есть пример где подобное решено лучшим способом? Очевидно, что ты работал только на говнопроектах. Подобный стиль написания "тестов" был актуален в начале нулевых в провинциальных аутсорс конторках где пахло луком, потом и пердежом
>>3454936 >Ты же создаешь пользователя > чтобы изменить поле в какой-то энитити Нуу, допустим этот метод контроллера по смене пароля юзера. Соответсвенно он принимает логин, oldPasswd, newPasswd. Суррогатный айдишник пользователь само собой не знает. И вот метод сервиса, который принимает User и делает ровно одно действие по save в jparepository. Но мы же не сможем создать User, поскольку не знаем id. Как в таком случае? Просто мне кажется, что тут лучше сделать промежуточный уровень дто, который одновременно не привязан ни к апи, ни к бд. Но в принципе, можно в качестве аргумента принимать и дто уровня апи, что возмооожно нарушение SRP.
>>3454958 Ну у тебя в ручке контроллера будет id в url и в теле жсон с паролями. Потом ты это тупо передаешь в сервисный слой типа UserServiceImpl.changePassword(id, old, new) и там уже достаешь через UserRepository юзера, меняешь ему пароль, сейвишь или еще как-нибудь делаешь
>>3454969 >будет id в url Вот честно, никогда не видел, чтобы у меня id спрашивали при смене пароля. Логин - это натуральный ключ, его обычно хватает. Наверно что-то типа того. PATCH /api/{login}/passwd { old_passwd: "" new_passwd: "" } Где body = ChangeUserPasswdRequestDto >UserServiceImpl.changePassword(id, old, new) И вот ты по сути предлагаешь этот дто развернуть в сигнатуру. Проблема такого подхода наверное только в том, что ну полей так-то дохуя может быть. И вот я предлагаю UserService#changePassword(login, changeUserPasswdDto), который маппится через маппер как раз на уровне контроллера. Внутри сервиса мы из этого дто уже получаем User энтитю, но она никогда не вытекает в сигнатуру. И вот например другой метод GET /api/{login}
Который дергает сервис UserService#getUser(login) : UserDto А потом в контроллере маппится в UserResponseDto. Преимущество такого подхода, что в UserDto мы можем сохранить id, и его гораздо проще использовать в других сервисах. Плюс на весив на один такой метод @PostAuthorize, не надо будет в других вешать = используя данный метод сервиса в других мы уверены, что во первых юзер существует и юзер совпадает с principal. И поскольку у нас есть id, можно использовать его напрямую в методах репозитория. Repository#find(userId, ...)
>>3454639 >>Дто в контроллере мапится на модель, а дальше передается в сервис. Мапинги могут и в сервисе быть
>>городить какие-то "дто между сервисом и репозиторием". Ты модель для этого как раз и используешь. Не очень хорошо только когда дто от контролера до репозитория долетает, но и это не критично.
>>Посмотри выступления Борисова Он сказал что спринг умер, ИИ всех заменит
>>Читай Анкл Бэба Ты в себе вкатуна выдаешь, раз ссылаешься на продавца курсов с сомнительной репутацией
>>3454784 >>Слой сервиса может использоваться как зависимость в других сервисах. Упомянутый тобой клин обычно работает в связке с ддд, а там такой хуйни уже быть не должно.
>>3454917 >>поменять там Имя, Почту, День рождения и т.д. >>Ты прямо в контроллере мапишь UserDto на User и передаешь его в сервис UserServiceImpl. А логику с валидацией, что например такое емеил не используется другим юзером, ты тоже в контролер засунешь? Ну или что пользователь с такими правами вообще имеет права менять свое имя?
>>3454917 >>UserServiceImpl >>Impl Тебе спринг нахуя дали? Зачем ты это проперженное говно из 90-х тащишь? Сам же потом будешь ныть какая жава громоздкая и как много ненужных абстракций. Оставь Impl кодогенераторам.
>>3453042 Вызываешь по Animal, идёт метод из Animal, очевидно же. На то статический метод и статический. Проблема в том что статический метод вызван по инстансу, что может путать.
>>3454810 Я когда увольнялся вакансия провисела примерно день на внутреннем портале, потом ее убрали. За две недели новый чел не появился, мб решили что ну и нахуй надо, чела с другого проекта просто дернули на пару дней в неделю коды писать.
Как грамотно скипнуть собес, если дают задачу с литкод? Или, например, вы считаете что надо тратить время, чтобы научиться решать всякую такую хуйню? Хотел бы узнать мнения.
>>3455191 Как грамотно скипнуть работу, если дают задачу из трекера? Или вы считаете что надо тратить время, чтобы решать всякую такую хуйню? Хотел бы узнать мнения.
>>3455954 А нейронка вообще request предлагает выкинуть. Прям как тута >>3454391 >называют по схеме XxxRequestPayload и XxxResponsePayload, слово payload часто опускают: GetUserRequest -> GetUserResponse
>>3456520 Data Access Object - это литерали то же самое, что и Repository. Абстракция над бд, чтобы в тестах было проще замокать.
import и имена классов и интерфейсов
Аноним17/05/25 Суб 02:52:57№3456676492
Привет всем. В python можно применять вот такую конструкцию: import "бла-бла-бла название" as "более короткое название" Вопрос: можно ли что-то подобное в java сделать? Т.е. чтобы при импорте двух классов с одинаковым названием можно было сделать этим классам иные названия?
>>3456676 Вот кстати какая причина, что скуфц алиасы не вводит? Перегрузка операторов даёт слишком много свободы. Именнованые параметры и дефолт значения не жаба вэй - билдеры наше все. Но блядь алиасы-то чем помешали.. Есть идеи?
>>3456818 В теории, можно же алиасом делать не имя класса, а путь до него. Т.е. если есть два класса com.zalupa.Poo com.xui.Poo Сделать что-то типа import com.xui as X import com.zalupa.Poo
И будет точное различие между X.Poo и Poo. И HashSet.Poo наверное не вызовет такого wtf.
>>3456818 Натянул же залупу на сову. Алиасы это просто еще один нейминг, не более опасный по части чтоб ввести в заблуждение чем имена обычных членов. Что мешает тебе сделать String hashSet = "Ololo ty loh"
>>3456736 Вангую что рано или поздно таки сделают.
Но спринговая лапша все равно не раскроет смысла алиасов. Нахрена тебе алиасы в кодовой базе, состоящей чуть менее чем полностью из сервисов, имена которых ты никогда не задублируешь? Алиасы прикольны в подходах, где дохуя полиморфизма, типа ФП на скале, там, какого нибудь... А спрингокульт в полиморфизм почти никак не умеет.