Why AbstractCollection does not implement equals()?

前端 未结 3 442
时光说笑
时光说笑 2021-01-18 05:49

Did you know that :

Map m1 = new HashMap();
Map m2 = new HashMap();
Sys         


        
相关标签:
3条回答
  • 2021-01-18 06:22

    I am not sure if thatt's the official reason, but AbstractCollection avoids adding semantic constraints on potential subclasses. The semantics of equality are determined by the nature of the concrete inheriting data structure, and in particular based on whether your structure is ordered and whether it allows duplicates.

    For example, Consider TreeSet, LinkedList, Bag, etc.

    BTW, In relation to the code you posted, what's the actual type of whatever is returned by values? That should be a subclass with a concrete implementation.. If your map is empty when you run this code, it's possible that you would be ending up with something that does not consider two empty sets equal.

    0 讨论(0)
  • 2021-01-18 06:25

    Per the contract of Collection#equals(), there is no general-purpose equals() methods for Collections, and thus AbstractCollection cannot provide one.

    Note that HashMap$Values is neither a Set nor a List, thus the quandary and in a sense the reason it does not support equals().

    0 讨论(0)
  • 2021-01-18 06:31

    Both AbstractList and AbstractSet extend AbstractCollection, and they have different behaviors for their equals() methods, specified by the interfaces List and Set. The interface for Collection says:

    While the Collection interface adds no stipulations to the general contract for the Object.equals, programmers who implement the Collection interface "directly" (in other words, create a class that is a Collection but is not a Set or a List) must exercise care if they choose to override the Object.equals.

    So AbstractCollection should definitely not override equals(). That said, I don't really know why HashMap$Values would not implement equals() itself.

    0 讨论(0)
提交回复
热议问题