Sized

Brian Goetz brian.goetz at oracle.com
Fri Nov 2 15:53:09 PDT 2012


I think you're focusing on another problem.  These things *have* size() 
methods already; I'm trying to capture this in a finer-grained 
interface.  The "size in O(1) time" is a whole orthogonal concern.

On 11/2/2012 6:27 PM, Kevin Bourrillion wrote:
> My mistake: CHM only has to walk through every /segment/ to add up the
> size, and I was thinking of it as actually traversing every element.
>
> In any event. It's undeniably true that there are numerous
> implementations of Collection out there that don't know their size
> without completely iterating themselves. I still say that if there's any
> value in Sized, it lies in making those implementations /not/ implement
> it while others do.
>
>
>
> On Fri, Nov 2, 2012 at 3:22 PM, Brian Goetz <brian.goetz at oracle.com
> <mailto:brian.goetz at oracle.com>> wrote:
>
>         Of course, some collections, like the key set of a
>         ConcurrentHashMap,
>         don't know their size any more than a garden-variety Iterable does.
>
>
>     That's not exactly true.  In the absence of interference from
>     concurrent modification, the key set of a CHM absolutely knows its
>     size.  It's just that in the presence of interference, the reported
>     size may be stale by the time you receive it.
>
>
>
>
> --
> Kevin Bourrillion | Java Librarian | Google, Inc. |kevinb at google.com
> <mailto:kevinb at google.com>
>


More information about the lambda-libs-spec-observers mailing list