Request for review : 7121314 : Behavior mismatch between AbstractCollection.toArray(T[] ) and its spec
Sean Chou
zhouyx at linux.vnet.ibm.com
Fri Mar 23 06:45:51 UTC 2012
Hi Ulf,
I'm sorry I didn't quite get your testcase. Will you please provide a
jtreg style testcase with main method ?
I was thinking you were worried by the comment "// inherits from
AbstractCollection.toArray()" and "map2", if that was the case, I would
like to modify.
On Fri, Mar 23, 2012 at 5:57 AM, Ulf Zibis <Ulf.Zibis at gmx.de> wrote:
> Hi Sean,
>
> bad news ;-) ...
>
> Am 22.03.2012 08:28, schrieb Sean Chou:
>
>> Hi Ulf,
>>
>> I'm glad you agreed my suggestion.
>>
>> To all:
>> Can this patch be committed as it has been reviewed by David Holmes
>> and Mike Duigou, and Ulf also says agreed ?
>>
>
> I agree with your implementation of AbstractCollection, but NOT with the
> test.
> For correct testing I suggest to use:
>
> /**
> *
> * @author Ulf Zibis
> */
> public class TestCollection<E> extends AbstractCollection<E> {
>
> private E[] elements;
> private int[] sizes;
> private int nextSize;
>
> public TestCollection(E[] elements) {
> this.elements = elements;
> setConcurrentSizeCourse(null);
> }
>
> void setConcurrentSizeCourse(int... sizes) {
> this.sizes = sizes == null ? new int[]{elements.length} : sizes;
> nextSize = 0;
> }
>
> @Override
> public int size() {
> return sizes[nextSize == sizes.length-1 ? nextSize : nextSize++];
> }
>
> @Override
> public Iterator<E> iterator() {
> return new Iterator<>() {
>
> int pos = 0;
>
> public boolean hasNext() {
> return pos < sizes[nextSize];
> }
>
> public E next() {
> return elements[pos++];
> }
>
> public void remove() {
> throw new UnsupportedOperationException(**"Not supported
> yet.");
> }
> };
> }
> }
>
> -Ulf
>
>
--
Best Regards,
Sean Chou
More information about the core-libs-dev
mailing list