Утвердите, что два LinkedHashMaps равны в одном и том же порядке в JUnit на Java 8.JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Утвердите, что два LinkedHashMaps равны в одном и том же порядке в JUnit на Java 8.

Сообщение Anonymous »

Мне нужно проверить полное равенство двух значений LinkedHashMap, включая их порядок.

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

@Test
public void test(){
Map actual = new LinkedHashMap();
actual.put("longer", 1);
actual.put("first", 1);
actual.put("thebiggest", 1);

Map expected = new LinkedHashMap();
expected.put("thebiggest", 1);
expected.put("longer", 1);
expected.put("first", 1);

System.out.println("===expected");
expected.entrySet().stream().forEach(n->System.out.println(n.getKey()));
System.out.println("===actual");
actual.entrySet().stream().forEach(n->System.out.println(n.getKey()));

assertEquals(expected, actual);
assertTrue(expected.equals(actual));
}
Все тесты пройдены, вывод отображается в консоли:

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

===expected
thebiggest
longer
first
===actual
longer
first
thebiggest
В документации везде написано, что LinkedHashMap сохраняет порядок вставки. Тогда почему утверждение о двух одинаковых, но разноупорядоченных картах дает истину?
И какую карту мне следует выбрать, если важен одинаковый порядок?

Подробнее здесь: https://stackoverflow.com/questions/402 ... -on-java-8
Ответить

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

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

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

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

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