----- Original Message -----
> From: "mark reinhold" <mark.reinh...@oracle.com>
> To: "Stuart Marks" <stuart.ma...@oracle.com>
> Cc: "core-libs-dev" <core-libs-dev@openjdk.org>, "jdk-dev" 
> <jdk-...@openjdk.org>
> Sent: Wednesday, October 12, 2022 1:17:20 AM
> Subject: New candidate JEP: 431: Sequenced Collections

> https://openjdk.org/jeps/431
> 
>  Summary: Introduce new interfaces to represent collections with a
>  defined encounter order. Each such collection has a well-defined first
>  element, second element, and so forth, up to the last element. It also
>  provides uniform APIs for accessing its first and last elements, and
>  for processing its elements in reverse order.

People will again think that i'm the grumpy guy but i prefer to voice my 
concerns.

- nobody cares, i'm back from Devoxx and nobody cares about Sequenced 
Collections, i've tried to ask several friends what they think about it and the 
answer was "meh".
  The bar to introduce new interfaces in the collection API is really really 
high given how the Java ecosystem works.
  Once a library starts to use those interfaces as method parameter, it 
pressures the other library authors to write methods that provides object typed 
as those interfaces.
  Not enough people care and the cost for the community (not only Oracle) is 
high, it looks like a recipe for failure.

- LinkedHashMap can be tweaked in two ways, by passing an access order as 3rd 
parameter of the constructor or by overriding removeEldesEntry(), in both cases 
the resulting LinkedHashMap is at odds with the contract of SequencedMap but 
the compiler will happily allow to see those LinkedHashMap as SequencedMap.

- LinkedHashMap/LinkedHashSet are dinosaurs, there are more efficient 
implementations of the concepts of ordered set / ordered map both in term of 
memory footprint and runtime execution, so adding new interfaces without 
exploring new implementations using Valhalla value class and in relation with 
the Collection Literal JEP seems premature to me.

> 
> - Mark

Rémi

Reply via email to