之前项目中一直使用数据库来做缓存,然后在某开源项目中看到别人使用保存序列化对象,然后反序列化取出来,效果也不错。下面上代码:
/**
* 保存对象
*
* @param ser 要保存的序列化对象
* @param file 保存在本地的文件名
* @throws IOException
*/
public static boolean saveObject(Context context, Serializable ser,
String file) {
FileOutputStream fos = null;
ObjectOutputStream oos = null;
try {
fos = context.openFileOutput(file, Context.MODE_PRIVATE);
oos = new ObjectOutputStream(fos);
oos.writeObject(ser);
oos.flush();
return true;
} catch ( Exception e ) {
e.printStackTrace();
return false;
} finally {
try {
oos.close();
} catch ( Exception e ) {
e.printStackTrace();
}
try {
fos.close();
} catch ( Exception e ) {
e.printStackTrace();
}
}
}
/**
* 读取对象
*
* @param file 保存在本地的文件名
* @return
* @throws IOException
*/
public static Serializable readObject(Context context, String file) {
if ( !isExistDataCache(context, file) )
return null;
FileInputStream fis = null;
ObjectInputStream ois = null;
try {
fis = context.openFileInput(file);
ois = new ObjectInputStream(fis);
return (Serializable) ois.readObject();
} catch ( FileNotFoundException e ) {
} catch ( Exception e ) {
e.printStackTrace();
// 反序列化失败 - 删除缓存文件
if ( e instanceof InvalidClassException ) {
File data = context.getFileStreamPath(file);
data.delete();
}
} finally {
try {
ois.close();
} catch ( Exception e ) {
}
try {
fis.close();
} catch ( Exception e ) {
}
}
return null;
}
上面两个方法分别是保存和读取。一般,我们在项目中,网络请求完成后,调用saveObject方法,当然了你的javaBean要实现Serializable接口。
public class Bean implements Serializable{}
读取的时候,只需要将读取的序列化对象强转为你保存的bean就行。有不清楚的请留言。
MyInfosBean bean = (MyInfosBean) CacheManager.readObject(context, getCacheName());