ArrayFactory SAM type / toArray

Brian Goetz brian.goetz at oracle.com
Thu Nov 8 08:53:44 PST 2012


But having them return Object undermines much of the point of adding 
these methods in the first place -- right now, we have

   Object[] toArray

and this forces unsafe casts.  We want Stream<T>.toArray() to return a 
T[].

We can still get to our goals for Collections/Streams with returning 
T[], but it could be creating some trouble for the future.

On 11/8/2012 11:46 AM, Raab, Donald wrote:
> I was thinking about this.  If the methods returns Object, could we not just have an if-statement check if it was one of the primitive types and return a new int[] or new double[] in the method if they do instead of making the reflective call?
>
>> -----Original Message-----
>> From: Brian Goetz [mailto:brian.goetz at oracle.com]
>> Sent: Thursday, November 08, 2012 11:44 AM
>> To: Raab, Donald [Tech]
>> Cc: lambda-libs-spec-experts at openjdk.java.net
>> Subject: Re: ArrayFactory SAM type / toArray
>>
>> On 9/19/2012 10:27 PM, Raab, Donald wrote:
>>> Could we add the following methods to the Class class?
>>>
>>> T[] emptyArray()
>>> T[] newArray(int size)
>>
>> I prototyped these, and they work fine for reference types but fall
>> apart for primitive arrays.  There *is* a Class literal for int.class,
>> but we can't make it return an int[] with this method.  (This is one
>> reason that Array.newInstance returns Object.)  Performance testing
>> would be needed to ensure they are competitive with alternatives.
>


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