getclass().getfield
时间: 2023-06-22 14:45:30 浏览: 149
`getClass().getField()` 是 Java 语言中的反射 API。它用于获取对象的类信息以及对象中的字段信息。具体来说,`getClass()` 方法返回对象的类信息,然后 `getField()` 方法获取该类中指定名称的公共字段。例如,以下代码可以获取对象 obj 中名为 fieldName 的公共字段:
```
Class<?> clazz = obj.getClass();
Field field = clazz.getField(fieldName);
```
需要注意的是,如果字段不是公共的,即使用 `private` 修饰符声明的,就需要使用 `getDeclaredField()` 方法来获取。此外,如果字段是静态的,则可以使用 `getDeclaredField()` 或 `getField()` 方法来获取。
相关问题
优化以下代码,Field[] fields = ReflectUtil.getFields(eventData.getClass()); for (Field field : fields) { if (Objects.isNull(field.getAnnotation(TranslateFileds.class))) { continue; } TranslateFiled[] actions = field.getAnnotationsByType(TranslateFiled.class); for (TranslateFiled action : actions) { Field translateFiledDesc = ReflectUtil.getField(eventData.getClass(), field.getName() + "Desc"); if (!translateFiledDesc.isAccessible()) { translateFiledDesc.setAccessible(true); } if (action.key().equals(field.get(eventData))) { translateFiledDesc.set(eventData, action.value()); } } }
这段代码的目的是获取类`eventData`的所有字段,并对带有注解`TranslateFileds`的字段进行操作。如果满足条件,则将该字段的描述设置为注解中的值。
可以对代码进行优化,比如在获取字段的过程中,就可以进行过滤,只获取带有注解`TranslateFileds`的字段,这样可以避免无用的循环,提高效率。
List<SchemaRowFilterCondition> schemaRowFilterConditions = JSONObject.parseArray(filterConditionList, SchemaRowFilterCondition.class); for (SchemaRowFilterCondition schemaRowFilterCondition : schemaRowFilterConditions) { String field = schemaRowFilterCondition.getField(); String camel = underlineToCamel(field); String key = schemaRowFilterCondition.getKey(); Field fieldsAndParentsField = fieldStream .filter(f -> StringUtils.equals(f.getName(), camel)) .findFirst() .orElseThrow(() -> new CustomException("大马猴来了", code)); Field f = object.getClass().getDeclaredField(camel); f.setAccessible(true); Object value = f.get(object); if (StringUtils.equals(key, value.toString()) && schemaRowRuleEo.getRowEditPermission()) { System.out.println("修改成功"); } else { throw new CustomException("大马猴来了", code); } }帮我优化代码
以下是对代码的优化建议:
1. 如果 `filterConditionList` 可能为空,需要在解析前进行非空判断。
2. 将对象的所有字段名转换为驼峰命名法,可以在对象初始化时进行,避免在循环中反复转换。
3. 将字段名与过滤条件的匹配逻辑抽离成一个方法,减少重复代码。
4. 将异常信息的文本提取成常量或配置文件中的字符串,避免在代码中硬编码。
5. 如果需要多次访问同一字段的值,可以先获取字段对象,避免反复通过反射获取。
6. 如果存在多个过滤条件,可以通过一次循环实现,避免多次循环。
下面是优化后的代码示例:
```
if (StringUtils.isNotBlank(filterConditionList)) {
// 将对象的所有字段名转换为驼峰命名法
Map<String, Field> fieldMap = Arrays.stream(object.getClass().getDeclaredFields())
.collect(Collectors.toMap(f -> underlineToCamel(f.getName()), Function.identity()));
boolean matched = true;
for (SchemaRowFilterCondition schemaRowFilterCondition : schemaRowFilterConditions) {
String field = schemaRowFilterCondition.getField();
String camel = underlineToCamel(field);
Field fieldInfo = fieldMap.get(camel);
// 检查字段是否存在
if (fieldInfo == null) {
throw new CustomException(FIELD_NOT_FOUND_MSG, code);
}
// 检查字段值是否匹配
if (!matchFieldValue(schemaRowFilterCondition.getKey(), fieldInfo, object)) {
matched = false;
break;
}
}
if (matched && schemaRowRuleEo.getRowEditPermission()) {
System.out.println("修改成功");
} else {
throw new CustomException(FIELD_VALUE_NOT_MATCH_MSG, code);
}
}
// 工具方法:获取对象属性值
private static Object getFieldValue(Field field, Object obj) throws IllegalAccessException {
field.setAccessible(true);
return field.get(obj);
}
// 工具方法:设置对象属性值
private static void setFieldValue(Field field, Object obj, Object value) throws IllegalAccessException {
field.setAccessible(true);
field.set(obj, value);
}
// 工具方法:检查字段值是否匹配
private static boolean matchFieldValue(String valueStr, Field field, Object obj) throws IllegalAccessException {
Object value = getFieldValue(field, obj);
return StringUtils.equals(valueStr, value.toString());
}
```
注意:上述优化示例仅供参考,具体优化方案需要根据实际情况进行调整。
阅读全文