optimize EnumWrapper.java

This commit is contained in:
开源海哥 2023-05-28 09:54:14 +08:00
parent db17b832a4
commit ccf9d38b37
2 changed files with 24 additions and 26 deletions

View File

@ -45,7 +45,7 @@ public class FlexEnumTypeHandler<E extends Enum<E>> extends BaseTypeHandler<E> {
@Override
public E getNullableResult(ResultSet rs, String columnName) throws SQLException {
Object value = rs.getObject(columnName, enumWrapper.getEnumPropertyType());
Object value = rs.getObject(columnName, enumWrapper.getPropertyType());
if (null == value && rs.wasNull()) {
return null;
}
@ -55,7 +55,7 @@ public class FlexEnumTypeHandler<E extends Enum<E>> extends BaseTypeHandler<E> {
@Override
public E getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
Object value = rs.getObject(columnIndex, enumWrapper.getEnumPropertyType());
Object value = rs.getObject(columnIndex, enumWrapper.getPropertyType());
if (null == value && rs.wasNull()) {
return null;
}
@ -65,7 +65,7 @@ public class FlexEnumTypeHandler<E extends Enum<E>> extends BaseTypeHandler<E> {
@Override
public E getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
Object value = cs.getObject(columnIndex, enumWrapper.getEnumPropertyType());
Object value = cs.getObject(columnIndex, enumWrapper.getPropertyType());
if (null == value && cs.wasNull()) {
return null;
}

View File

@ -29,13 +29,13 @@ public class EnumWrapper<E extends Enum<E>> {
private static final Map<Class, EnumWrapper> cache = new ConcurrentHashMap<>();
private Class<?> enumClass;
private boolean hasEnumValueAnnotation = false;
private Class<?> enumPropertyType;
private Class<?> enumClass;
private E[] enums;
private Field property;
private Method getter;
private boolean hasEnumValueAnnotation = false;
private Class<?> propertyType;
private Method getterMethod;
public static <R extends Enum<R>> EnumWrapper<R> of(Class<?> enumClass) {
return MapUtil.computeIfAbsent(cache, enumClass, EnumWrapper::new);
@ -43,6 +43,7 @@ public class EnumWrapper<E extends Enum<E>> {
public EnumWrapper(Class<E> enumClass) {
this.enumClass = enumClass;
this.enums = enumClass.getEnumConstants();
Field enumValueField = ClassUtil.getFirstField(enumClass, field -> field.getAnnotation(EnumValue.class) != null);
if (enumValueField != null) {
@ -50,24 +51,23 @@ public class EnumWrapper<E extends Enum<E>> {
}
if (hasEnumValueAnnotation) {
String fieldGetterName = "get" + StringUtil.firstCharToUpperCase(enumValueField.getName());
String getterMethodName = "get" + StringUtil.firstCharToUpperCase(enumValueField.getName());
Method getterMethod = ClassUtil.getFirstMethod(enumClass, method -> {
Method getter = ClassUtil.getFirstMethod(enumClass, method -> {
String methodName = method.getName();
return methodName.equals(fieldGetterName) && Modifier.isPublic(method.getModifiers());
return methodName.equals(getterMethodName) && Modifier.isPublic(method.getModifiers());
});
enumPropertyType = ClassUtil.getWrapType(enumValueField.getType());
enums = enumClass.getEnumConstants();
propertyType = ClassUtil.getWrapType(enumValueField.getType());
if (getterMethod == null) {
if (getter == null) {
if (Modifier.isPublic(enumValueField.getModifiers())) {
property = enumValueField;
} else {
throw new IllegalStateException("Can not find \"" + fieldGetterName + "()\" method in enum: " + enumClass.getName());
throw new IllegalStateException("Can not find method \"" + getterMethodName + "()\" in enum: " + enumClass.getName());
}
} else {
getter = getterMethod;
this.getterMethod = getter;
}
}
}
@ -75,9 +75,7 @@ public class EnumWrapper<E extends Enum<E>> {
public Object getEnumValue(E object) {
try {
return getter != null
? getter.invoke(object)
: property.get(object);
return getterMethod != null ? getterMethod.invoke(object) : property.get(object);
} catch (Exception e) {
throw FlexExceptions.wrap(e);
}
@ -93,12 +91,12 @@ public class EnumWrapper<E extends Enum<E>> {
return null;
}
public Class<?> getEnumClass() {
return enumClass;
public boolean hasEnumValueAnnotation() {
return hasEnumValueAnnotation;
}
public Class<?> getEnumPropertyType() {
return enumPropertyType;
public Class<?> getEnumClass() {
return enumClass;
}
public E[] getEnums() {
@ -109,11 +107,11 @@ public class EnumWrapper<E extends Enum<E>> {
return property;
}
public Method getGetter() {
return getter;
public Class<?> getPropertyType() {
return propertyType;
}
public boolean hasEnumValueAnnotation() {
return hasEnumValueAnnotation;
public Method getGetterMethod() {
return getterMethod;
}
}