RFR (S): JDK-8039916: AnnotatedType.getType() of a Executable parameters may return wrong type
Remi Forax
forax at univ-mlv.fr
Wed Jun 4 15:06:48 UTC 2014
On 06/04/2014 12:34 PM, Paul Sandoz wrote:
> On Jun 4, 2014, at 12:25 PM, Paul Sandoz <Paul.Sandoz at oracle.com> wrote:
>> You might consider the following a more streamy way, not tested! up to you :-)
>>
>> private static Object[][] provider() {
>> Stream<? extends Executable> s = filterData(Test.class.getMethods(), null);
>> s = Stream.concat(s, filterData(Test.class.getConstructors(), null));
>> s = Stream.concat(s, filterData(Test.class.getConstructors(), null));
>> return streamToArray(s);
>> }
>>
>> private static Stream<? extends Executable> filterData(Executable[] es, Class<?> c) {
>> return Stream.of(es).filter(m -> m.getDeclaringClass() == c);
>> }
> Plus you can drop the "? extends" bit of "? extends Executable", that was a hangover from some other mini experiment.
returning a Foo<? extends XXX> is usually a design error (apart from
covariant return type in case of overriding but usually it's because the
API was designed before the introduction of generics), because all
client codes will have to declare a Foo<? extends XXX>.
Here, it's better to introduce a type variable
private static <E extends Executable> Stream<E> filterData(E[] es, Class<?> c) {
return Stream.of(es).filter(m -> m.getDeclaringClass() == c);
}
>
> Paul.
>
>
regards,
Rémi
More information about the core-libs-dev
mailing list