3 回答

TA貢獻1777條經驗 獲得超3個贊
是的 只需使用二進制序列化即可。您必須使用每個對象,implements Serializable但是從那里開始很簡單。
如果要避免實現Serializable接口,您的另一種選擇是使用反射,并使用以下過程來對緩沖區進行數據讀寫:
/**
* Sets all int fields in an object to 0.
*
* @param obj The object to operate on.
*
* @throws RuntimeException If there is a reflection problem.
*/
public static void initPublicIntFields(final Object obj) {
try {
Field[] fields = obj.getClass().getFields();
for (int idx = 0; idx < fields.length; idx++) {
if (fields[idx].getType() == int.class) {
fields[idx].setInt(obj, 0);
}
}
} catch (final IllegalAccessException ex) {
throw new RuntimeException(ex);
}
}

TA貢獻1806條經驗 獲得超8個贊
正如我在其他類似問題中提到的那樣,您可能需要考慮壓縮數據,因為默認的Java序列化有點冗長。您可以通過在對象流和字節流之間放置一個GZIPInput / OutputStream來實現。
添加回答
舉報