1.错误信息
相关代码:
User user1 = new User("王五", 111111);
LOGGER.info("user1.password = " + pwdFiled.getInt(user1));
pwdFiled.setInt(user1, 321);
LOGGER.info("user1.password = " + pwdFiled.getInt(user1));
报错信息:
Exception in thread "main" java.lang.IllegalAccessException: Class pers.hanchao.reflect.fields.ReflectFieldDemo can not access a member of class pers.hanchao.reflect.common.User with modifiers "private"
at sun.reflect.Reflection.ensureMemberAccess(Reflection.java:102)
at java.lang.reflect.AccessibleObject.slowCheckMemberAccess(AccessibleObject.java:296)
at java.lang.reflect.AccessibleObject.checkAccess(AccessibleObject.java:288)
at java.lang.reflect.Field.get(Field.java:390)
at pers.hanchao.reflect.fields.ReflectFieldDemo.main(ReflectFieldDemo.java:126)
2.错误分析
通过反射操作类的私有(private)成员变量时,需要通过field.setAccessible(true)
将字段设置为可以访问的。
3.错误解决
//通过filed.setAccessible(true)设置字段是为可访问
pwdFiled.setAccessible(true);
User user1 = new User("王五", 111111);
LOGGER.info("user1.password = " + pwdFiled.getInt(user1));
pwdFiled.setInt(user1, 321);
LOGGER.info("user1.password = " + pwdFiled.getInt(user1));
运行结果:
2018-03-04 11:11:07 INFO ReflectFieldDemo:139 - user1.password = 111111
2018-03-04 11:11:07 INFO ReflectFieldDemo:141 - user1.password = 321