Sized
Brian Goetz
brian.goetz at oracle.com
Thu Nov 8 11:37:50 PST 2012
So, what I was really hoping for was feedback on this approach to
providing a migration path from 32 to 64 bit collections (and
collection-like things). Any feedback?
On 11/5/2012 7:10 PM, Kevin Bourrillion wrote:
> All right, all right. Exiting pain in the ass mode. I can get behind
> "Sized means it has a size() method, plain and simple."
>
> To the extent that I think Iterable should extend it (which I'm still
> trying to convince myself one way or the other of), I can still just
> save that argument for another day.
>
> Seems a fine plan. I assume Map will extend it, and a future version of
> Guava that worked with JDK 8 would have Multimap, etc. extend it too.
> (Multisets in particular have wound up wanting to be long-sized many a
> time.)
>
>
> On Mon, Nov 5, 2012 at 3:48 PM, Brian Goetz <brian.goetz at oracle.com
> <mailto:brian.goetz at oracle.com>> wrote:
>
> The real purpose is as I specified earlier -- providing a migration
> path for the 32-bit size limitation that is hard-coded into
> Collections. There are a number of size-like methods in new APIs
> and I want to select neither of the following signatures:
>
> int size()
> long size()
>
> Instead, I want to make a choice based on a framework for migration
> towards 64-bit collections. The Sized I proposed was one possible
> way to do this in an organized way. But this was all in the first
> message on this thread?
>
> On Nov 5, 2012, at 6:33 PM, Kevin Bourrillion wrote:
>
>> I think you're implying that size() doesn't make sense for such an
>> Iterable. Correct?
>>
>> But why not? You're describing an (imho sociopathic, but that's
>> beside the point) iterable that is content to be destroyed upon a
>> single use. Calling size() would just be one of the ways to use it
>> and destroy it. I see nothing inconsistent about that.
>>
>> While it probably seems like I'm just trying to be a pain --
>> probably seems a /lot/ like that -- all I'm after is some clear
>> way to explain the purpose of this new type, that makes it make
>> sense to people when they should use it and when they shouldn't.
>> I'm asking questions to understand this rationale so that I can
>> explain it myself. But I'm just not following it yet.
>>
>>
>> On Mon, Nov 5, 2012 at 3:15 PM, Brian Goetz
>> <brian.goetz at oracle.com <mailto:brian.goetz at oracle.com>> wrote:
>>
>> Iterable doesn't guarantee that you can iterate the source
>> more than once. It is entirely consistent with the Iterable
>> spec that iterator() always returns the same Iterator.
>>
>> On Nov 4, 2012, at 10:31 AM, Kevin Bourrillion wrote:
>>
>>> On Fri, Nov 2, 2012 at 3:53 PM, Brian Goetz
>>> <brian.goetz at oracle.com <mailto:brian.goetz at oracle.com>> wrote:
>>>
>>> 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.
>>>
>>>
>>> Sorry -- I was just going off the initial description, "It is
>>> useful to indicate that an aggregate knows its size." If the
>>> real goal instead is only to distinguish when an aggregate
>>> "decides to expose a size() operation for /whatever/ reason",
>>> then right, there's no problem here.
>>>
>>> But this new understanding doesn't make clear the reason why
>>> Iterable shouldn't go ahead and extend Sized as well. As Mike
>>> says, it "can determine it's size and that size()
>>> implementation is at least as good as getting an iterator and
>>> counting the items" -- that's undeniably the case. And as you
>>> say, the performance question is orthogonal.
>>>
>>> But I think you don't want that, so I am still missing what
>>> the distinction between Sized and not Sized is supposed to be.
>>>
>>>
>>> --
>>> Kevin Bourrillion | Java Librarian | Google,
>>> Inc. |kevinb at google.com <mailto:kevinb at google.com>
>>>
>>
>>
>>
>>
>> --
>> Kevin Bourrillion | Java Librarian | Google,
>> Inc. |kevinb at google.com <mailto:kevinb at google.com>
>>
>
>
>
>
> --
> 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