之前一直不知道反射到底能用在哪里,直到我看到了公司OA的考勤表设计:
DAY表示每个月的天数,后面的数字表示每月的几号,A表示上午,B表示下午。比如DAY01A用以表示当月1号的出勤情况。
所以,这个表用以记录考勤数据的字段共有62个。。。
后来想用这个每天考勤数据,才发现反射真是个好东西。
以三天数据为例:
{
"day01a":0,
"day01b":1,
"day02a":2,
"day02b":3,
"day03a":4,
"day03b":5
}
如果要获取day02b字段的值:
public class OaTest {
public static void main(String[] args) {
Day day = new Day();
day.setDay01a(0);
day.setDay01b(1);
day.setDay02a(2);
day.setDay02b(3);
day.setDay03a(4);
day.setDay03b(5);
//现在要获取字段day02b的值
Field[] declaredFields = day.getClass().getDeclaredFields();
try {
for (Field field : declaredFields) {
//字段名称
String name = field.getName();
if (name.equals("day02b")) {
//用于获取private成员变量
field.setAccessible(true);
System.out.println("字段名称:" + name);
//字段值
Object o = field.get(day);
System.out.println("要获取字段的值:" + o);
}
}
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
//对应表实体
class Day {
private int day01a;
private int day01b;
private int day02a;
private int day02b;
private int day03a;
private int day03b;
//省略get,set方法
}
执行结果:
字段名称:day02b
要获取字段的值:3
所以要获取目标字段值,只需要通过日期拼接成所需字段的名称,然后通过上面方法进行字段值获取即可。