我有一个参数 SparseArray<int[]>
,并想要序列化它。
但是writeSparseArray(Object)
对于 Parcelable 似乎不支持 int[]
。
还有其他方法可以序列化 SparseArray<int[]>
,或者只更改int[]
反对?
最佳答案
我检查了 Parcel.writeSparseArray() 方法,在我看来存在一些问题,因为该方法应该像 writeList() 一样通用。看起来像:
public final void writeSparseArray(SparseArray<Object> val)
应该是
public final void writeSparseArray(SparseArray<? extends Object> val)
或
public final <T> void writeSparseArray(SparseArray<T> val)
或
public final void writeSparseArray(SparseArray val)
因此,您必须为 SparseArray 对象实现您自己的此方法的实现。我不确定这是否是最好的解决方案,但您可以尝试以下方法:
public void writeSparseArray(Parcel dest, SparseArray<int[]> sparseArray) {
if (sparseArray == null) {
dest.writeInt(-1);
return;
}
int size = sparseArray.size();
dest.writeInt(size);
int i=0;
while (i < size) {
dest.writeInt(sparseArray.keyAt(i));
dest.writeIntArray(sparseArray.valueAt(i));
i++;
}
}
private SparseArray<int[]> readSparseArrayFromParcel(Parcel source){
int size = source.readInt();
if (size < 0) {
return null;
}
SparseArray sa = new SparseArray(size);
while (size > 0) {
int key = source.readInt();
int[] value = source.createIntArray();
sa.put(key, value);
size--;
}
return sa;
}
关于java - writeSparseArray 支持 SparseArray<int[]> 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27897331/