LinkedHashMap Java 8 的 JUnit 顺序

egn*_*ork 2 java junit

我需要检查两个地图的完全相等性,包括它们的顺序

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

        Map<String, Integer> 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));
    }
Run Code Online (Sandbox Code Playgroud)

所有测试均通过,控制台输出:

===expected
thebiggest
longer
first
===actual
longer
first
thebiggest
Run Code Online (Sandbox Code Playgroud)

文档中到处都写到 LinkedHashMap 保持插入顺序。那么为什么两个相同但不同的有序映射的断言给出 true 呢?如果平等顺序很重要,我应该采取什么地图?

Thi*_*ilo 5

for a的定义equalsMap是它们具有相同的条目集,无论顺序如何。

比较指定对象与此映射是否相等。如果给定对象也是一个映射并且两个映射表示相同的映射,则返回 true。更正式地说,如果 m1.entrySet().equals(m2.entrySet()),则两个映射 m1 和 m2 表示相同的映射。这可以确保 equals 方法在 Map 接口的不同实现中正常工作。

如果您想断言相同的迭代顺序,您可以将两个迭代复制到列表中并比较列表。