我正试图掌握onSaveInstanceState
method in class View
(不是the one in class Activity
)。该方法确实返回Parcelable
。我从View
派生了我自己的ViewGroup
并覆盖了该方法以保存我自己的状态。但是当国家被拯救时,我得到了一个例外:
java.lang.IllegalStateException:
Derived class did not call super.onSaveInstanceState()
这是真的,但简单地调用这种方法对我来说似乎不够。那我该怎么做呢?如果该方法将被传递Parcel
来写入,我可以简单地将同一个包传递给超类,这样就可以按顺序写入。但这是一个回报值。
我是否应该将此返回的对象作为我自己的Parcelable
表示的成员包含在内,如果需要,可以使用Parcel.writeParcelable
将其与我自己的数据一起编组?或者是否有更好的方法来处理父调用和可分割对象的链接?如果是这样,我在加载超类的实例状态时应该使用哪个类加载器?
答案 0 :(得分:4)
由于zapl没有将他的评论转化为答案,我正在这样做。
有没有更好的方法来处理父调用和可分配对象的链接?
实现此目标的规范方法是,为View.BaseSavedState
派生的已保存数据创建自己的类,而后者又来自AbsSavedState
。您可以调用父类的onSaveInstance
处理程序,并将结果对象传递给您自己的类的构造函数。在恢复数据时,getSuperState
会将实例定位到父类。
典型的代码示例如下所示:
static class SavedState extends View.BaseSavedState {
// include own data members here
public SavedState(Parcelable superState) {
super(superState);
}
private SavedState(Parcel in) {
super(in);
// read own data here
}
@Override public void writeToParcel(Parcel out, int flags) {
super.writeToParcel(out, flags);
// write own data here
}
public static final Parcelable.Creator<SavedState> CREATOR =
new Parcelable.Creator<SavedState>() {
public SavedState createFromParcel(Parcel in) { return SavedState(in); }
public SavedState[] newArray(int size) { return new SavedState[size]; }
};
}
@Override public Parcelable onSaveInstanceState() {
SavedState state = new SavedState(super.onSaveInstanceState());
// set data members here
return state;
}
@Override public void onRestoreInstanceState(Parcelable parcelable) {
SavedState state = (SavedState)parcelable;
super.onRestoreInstanceState(state.getSuperState());
// restore from data members here
}
以上内容改编自Cyril Mottier的this presentation,但也应该与设计师一般打算如何使用这个类一致。
我是否应该将此返回的对象作为我自己的
Parcelable
表示的成员包含在内,如果需要,可以使用Parcel.writeParcelable
将其与我自己的数据一起编组?
虽然上面提到的上述内容似乎更受欢迎,behind the scenes它也依赖于writeParcelable
。因此,如果有理由不使用该基类,只需调用writeParcelable
来存储超类的状态应该没问题。
在加载超类的实例状态时,我应该使用哪个类加载器?
current implementation of AbsSavedState
确实使用null
作为类加载器参数,导致使用默认的类加载器。但是,该行代码标有FIXME
条评论,因此有一天可能会更改。