On 2024/09/26 11:36:49 Dávid Szigecsán wrote:
...
> Map.Entry.equals() howewer checks if the other is an instance of the same
> class. 

Dávid,

It does not, in Java 8 and 23, the method is abstract and does not define code, 
but the Javadoc does define expected behavior.

I imagine that it was not changed to a default method for compatibility.

Gary

So if we want them to be equals, we should change the Map.Entry,
> that is out of our limit of power. To make it symmetric we could check for
> the instances of the same class also (and return false in this case), but I
> think we don't want this.
> 
> Dávid
> 
> Alex Tsvetkov <a.e.tsvet...@gmail.com> ezt írta (időpont: 2024. szept. 26.,
> Cs 13:11):
> 
> > Hi.
> >
> > I found a bug in the implementation of the method `equals` of class `Pair`.
> >
> > Implementation must be symmetric. Current implementation is not.
> >
> > Her test showing the problem:
> >
> > ```
> >
> > @Test
> > void run() {
> >     var pair = Pair.of("a", "b");
> >     var entry = new Map.Entry<String, String>() {
> >         public String getKey() { return "a"; }
> >         public String getValue() { return "b"; }
> >         public String setValue(String value) { return null; }
> >     };
> >     assertTrue(pair.equals(entry)); // true
> >     assertTrue(entry.equals(pair)); // false
> > }
> > ```
> >
> 

---------------------------------------------------------------------
To unsubscribe, e-mail: user-unsubscr...@commons.apache.org
For additional commands, e-mail: user-h...@commons.apache.org

Reply via email to