FinalReflectionobj = new FinalReflection();System.out.println(FinalReflection.stmark);System.out.println(obj.inmark);Field staticFinalField = FinalReflection.class.getDeclaredField("stmark");Field instanceFinalField = FinalReflection.class.getDeclaredField("inmark");staticFinalField.setAccessible(true);instanceFinalField.setAccessible(true);//EXTRA CODE//Modify the final using reflectionField modifiersField = Field.class.getDeclaredField("modifiers");modifiersField.setAccessible(true);modifiersField.setInt(staticFinalField, staticFinalField.getModifiers() & ~Modifier.FINAL);instanceFinalField.set(obj, 100);System.out.println(obj.inmark);staticFinalField.set(FinalReflection.class, 101);System.out.println(FinalReflection.stmark);该解决方案并非没有缺点,它可能无法在所有情况下都有效:
如果
final在字段声明中将字段初始化为编译时常量,则对该字段的更改
final可能不可见,因为该最终字段的使用会在编译时用编译时常量替换。
另一个问题是,该规范允许对
final字段进行积极的优化。在线程内,可以
final使用
final在构造函数中不进行的对字段的那些修改来重新排序对字段的读取。
更多关于这也是在这个类似的问题解释。



