под одну строку может быть несколько значений, которые выбираются случайным образом
И мне нужно сделать маппинг строки (условно, "test.first-string-command") на команду (enum Command)
Соответственно, приходит на сервер текст, нужно найти значение (команду) именно для него
Соответственно, если значений "test.first-string-command" штук 10 на 5 языках - то бегать за ними в таблицу будет совсем не весело. А если потенциально команд пару сотен и для каждой такое, а нужно всего одну найти?
Как лучше это оформить? При старте приложения вытягивать всё в статическую HashMap<String, Command> и потом в ней искать соответствие по ключу?
Это пока самое оптимальное что пришло в голову
Одна из идей была идти в бандл и в нужном языке искать ключ по значению, но даже если опустить вопрос что реализаций в том же спринговом MessageSource который сейчас используется нет и нужно будет городить свою - вопрос опять же оптимальности на каждую команду перебирать файл
Был ещё вариант держать под каждого пользователя доступные ему в данный момент команды в его языке, но откинул эту идею как нецелесообразную. Во-первых дублирование, во-вторых где адекватно столько данных держать без потерь во времени доступа к ним и модификации в зависимости от уймы факторов
Неправильно делаете
https://docs.oracle.com/javase/tutorial/i18n/
Что неправильно делаем? Мы уже используем ресурс бандл для переводов Вопрос не оптимизации Вопрос что нужно по переводу найти его код и от него соответствующую команду Этого нет в реализациях MessageSource, а пилить свой - вариант с хешмапой, мне кажется, будет продуктивнее
Обсуждают сегодня