diff --git a/hutool-core/src/main/java/org/dromara/hutool/core/reflect/TypeUtil.java b/hutool-core/src/main/java/org/dromara/hutool/core/reflect/TypeUtil.java index ffceb4ed7..a94d168b2 100644 --- a/hutool-core/src/main/java/org/dromara/hutool/core/reflect/TypeUtil.java +++ b/hutool-core/src/main/java/org/dromara/hutool/core/reflect/TypeUtil.java @@ -343,8 +343,9 @@ public class TypeUtil { final Type[] genericInterfaces = clazz.getGenericInterfaces(); if (ArrayUtil.isNotEmpty(genericInterfaces)) { for (final Type genericInterface : genericInterfaces) { - if (genericInterface instanceof ParameterizedType) { - result.add((ParameterizedType) genericInterface); + final ParameterizedType parameterizedType = toParameterizedType(genericInterface); + if(null != parameterizedType){ + result.add(parameterizedType); } } } diff --git a/hutool-core/src/test/java/org/dromara/hutool/core/reflect/Issue3516Test.java b/hutool-core/src/test/java/org/dromara/hutool/core/reflect/Issue3516Test.java new file mode 100644 index 000000000..214da9a64 --- /dev/null +++ b/hutool-core/src/test/java/org/dromara/hutool/core/reflect/Issue3516Test.java @@ -0,0 +1,34 @@ +package org.dromara.hutool.core.reflect; + +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; + +import java.lang.reflect.Type; +import java.util.function.Function; + +public class Issue3516Test { + + @Test + public void getTypeArgumentTest() { + final Type typeArgument = TypeUtil.getTypeArgument(Demo.class, 0); + Assertions.assertEquals(B.class, typeArgument); + } + + static class Demo implements A2B{ + @Override + public A apply(final B b) { + return new A(); + } + } + + static class A { + private String name; + } + + static class B { + private String name; + } + + interface A2B extends Function { + } +}