java 反射类 实例化_java-如何在Android上通过反射实例化成员类
我有一個保存/加載框架,該框架應該保存任意對象圖.這包括非靜態嵌套類的實例.
嵌套類require為其創建它們的父類的實例所擁有,并且嵌套類使用合成字段知道它屬于哪個實例.
作為一個簡單的例子,我介紹這個類:
public class Foo implements Savable {
private class Bar implements Savable {
public void saveState(Saver saver) {
saver.putInt(3);
}
}
private Bar myBar = new Bar();
public void saveState(Saver saver) {
saver.putSavable(myBar);
}
}
在“標準”編譯器上,以下代碼可以很好地接收一個對象(myBar),找到其父對象(Foo的特定實例)并保留其對子對象的引用:
if (objectClass.isMemberClass()) {
//We are a member class, which means we are a non-static inner class, and therefore must save our parent.
Field[] fields = objectClass.getDeclaredFields();
//We loop through each of our fields to find the synthetic field created by the compiler that points to our parent.
for (Field f : fields) {
String name = f.getName();
//The synthetic field pointing to the parent is named something like "this$0". At least, with the "standard" compiler it is.
if (name.startsWith("this$")) {
f.setAccessible(true);
Savable parent = (Savable)f.get(objectClass);
saver.putSavable("_parent", parent);
break;
}
}
if (!saver.containsKey("_parent")) {
throw new RuntimeException("Could not find the owner of inner class: " + objectClass);
}
}
因此,就像我說的那樣,這在“標準”編譯器上可以正常工作.然后在加載時,會發生類似的事情,除了我尋找一個構造函數,該構造函數接受父類的實例并實例化它,并傳入父類.
但!
它不適用于Android VM.沒有合成字段,并且構造函數都看起來很正常,就像它們沒有采用父實例一樣.
我在這里嗎?該虛擬機顯然不喜歡我的方法.在不要求內部類知道它們需要保存對其父類實例的引用的情況下,我在這里可以做些什么嗎?
總結
以上是生活随笔為你收集整理的java 反射类 实例化_java-如何在Android上通过反射实例化成员类的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python数据分析简答题_Python
- 下一篇: android 底部滑动效果怎么做,An