Почему средство сортировки Java для венгерской локали смешивает E и É?JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Почему средство сортировки Java для венгерской локали смешивает E и É?

Сообщение Anonymous »

Я хочу упорядочить огромный список стран и заметил, что, например, E и É рассматриваются как равные. Но в венгерской грамматике E стоит перед É, поэтому следует добавить правило: «E < É».
Пример кода:

Код: Выделить всё

List countries = List.of("Észak-korea", "Észtország", "Eritrea", "Etiópia", "El Salvador");
Locale locale = Locale.of("hu", "HU");
Collator collator = Collator.getInstance(locale);
List orderedCountries = countries.stream().sorted(collator).toList();
System.out.println(orderedCountries);
Результат следующий:

Код: Выделить всё

[El Salvador, Eritrea, Észak-korea, Észtország, Etiópia]
Ожидаемый результат:

Код: Выделить всё

[El Salvador, Eritrea, Etiópia, Észak-korea, Észtország]
Настройка силы сортировки ничего не меняет. В наборе правил явно не учитывается порядок подчеркнутых букв по сравнению с их простыми буквенными аналогами. Например, A < Á, I < I, E < É и т. д.
Я использую OpenJDK 21 (21.0.2).
Почему существует набор правил для венгерского языка, который не соответствует правилам венгерского языка? Я не хочу создавать собственные правила для реализации той функциональности, которая уже должна быть там. Возможно, на этот вопрос есть хороший ответ. Или есть другой метод достижения ожидаемого результата с помощью библиотек Java по умолчанию?

Подробнее здесь: https://stackoverflow.com/questions/798 ... and-%c3%89
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»