定义一个实现序列化接口的bean 并重写readObject和writeObject方法
实现类中所有的字段都使用transient 修饰、表示在序列化的时候不保存该字段
package mytest;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
public class TestBean implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
private transient Long code;
private transient String text;
private transient Date d;
private transient List<String> list;
private transient List<String> list2;
public Long getCode() {
return code;
}
public void setCode(Long code) {
this.code = code;
}
public String getText() {
return text;
}
public void setText(String text) {
this.text = text;
}
public Date getD() {
return d;
}
public void setD(Date d) {
this.d = d;
}
public List<String> getList() {
return list;
}
public void setList(List<String> list) {
this.list = list;
}
public List<String> getList2() {
return list2;
}
public void setList2(List<String> list2) {
this.list2 = list2;
}
/**
* 序列化对象的方法的writeObject
* @param os
* @throws IOException
* @throws IllegalAccessException
* @throws IllegalArgumentException
*/
private void writeObject(ObjectOutputStream os) throws IOException, IllegalArgumentException,
IllegalAccessException {
os.defaultWriteObject();//java对象序列化默认操作
Field[] fs = this.getClass().getDeclaredFields();
for (Field field : fs) {
String f = field.getName();
if ("serialVersionUID".equals(f))
continue;
int mod = field.getModifiers();
if (Modifier.isTransient(mod))
setObjectOutputStream(os, field);
}
}
/**
* 反序列化对象的方法readObject
* @param is
* @throws IOException
* @throws ClassNotFoundException
* @throws IllegalArgumentException
* @throws IllegalAccessException
*/
private void readObject(ObjectInputStream is) throws IOException, ClassNotFoundException, IllegalArgumentException,
IllegalAccessException {
is.defaultReadObject();//java对象反序列化默认操作
Field[] fs = this.getClass().getDeclaredFields();
for (Field field : fs) {
String f = field.getName();
if ("serialVersionUID".equals(f))
continue;
int mod = field.getModifiers();
if (Modifier.isTransient(mod))
readObjectInputStream(is, field);
}
}
@SuppressWarnings("unchecked")
private void setObjectOutputStream(ObjectOutputStream os, Field field) throws IOException,
IllegalArgumentException, IllegalAccessException {
Class<?> type = field.getType();
Object v = field.get(this);
if (type == String.class || type == Long.class || type == Integer.class) {
os.writeObject(v);
} else if (type == java.util.Date.class || type == java.sql.Date.class) {
os.writeObject(v);
} else if (type == int.class) {
os.writeInt(Integer.parseInt(v.toString()));
} else if (type == long.class) {
os.writeLong(Long.parseLong(v.toString()));
} else if (type == List.class) {
List<String> l = (List<String>) v;
os.writeInt(l.size());
for (String s : l) {
os.writeObject(s);
}
}
}
private void readObjectInputStream(ObjectInputStream is, Field f) throws IllegalArgumentException,
IllegalAccessException, IOException, ClassNotFoundException {
Class<?> type = f.getType();
if (type == String.class || type == Long.class || type == Integer.class) {
f.set(this, is.readObject());
} else if (type == java.util.Date.class || type == java.sql.Date.class) {
f.set(this, is.readObject());
} else if (type == int.class) {
f.set(this, is.readInt());
} else if (type == long.class) {
f.set(this, is.readLong());
} else if (type == List.class) {
int size = is.readInt();
List<String> setList = new ArrayList<String>();
for (int i = 0; i < size; i++) {
Object data = is.readObject();
setList.add(data.toString());
}
f.set(this, setList);
}
}
}
测试类
package mytest;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.Date;
public class SerializeTest {
public static void main(String[] args) throws IOException, ClassNotFoundException {
TestBean tb = new TestBean();
// tb.setCode(null);
tb.setText("中文");
tb.setD(new Date());
List<String> list = new ArrayList<String>();
list.add("1");
list.add("2");
list.add("3");
list.add("4");
tb.setList(list);
List<String> list2 = new ArrayList<String>();
list2.add("1");
list2.add("2");
list2.add("3");
list2.add("4");
list2.add("5");
tb.setList2(list2);
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream out = new ObjectOutputStream(bos);
out.writeObject(tb);
out.flush();
out.close();
System.out.println(new String(bos.toByteArray()));
System.out.println(bos.size());
ObjectInputStream in = new ObjectInputStream(new ByteArrayInputStream(bos.toByteArray()));
TestBean tb2 = (TestBean) in.readObject();
System.out.println(tb2.getD());
}
}
经过测试一个序列化对象的大小有:170字节
经过处理后大小变成:92字节
代码写得比较丑、以后再慢慢优化
只是为了保存一下
分享到:
相关推荐
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。 17、...
5.21 序列化Python对象 第六章:数据编码和处理 6.1 读写CSV数据 6.2 读写JSON数据 6.3 解析简单的XML数据 6.4 增量式解析大型XML文件 6.5 将字典转换为XML 6.6 解析和修改XML 6.7 利用命名空间解析XML...
|------ 3.5 利用序列化进行文件读写 |------ 3.6 MFC中所提供的各种视类介绍 +-- 第四章 窗口控件 |------ 4.1 Button |------ 4.2 Static Box |------ 4.3 Edit Box |------ 4.4 Scroll Bar |------ 4.5 List Box/...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。 14、Overload...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
在schema browser的帮助下,可以方便的浏览数据库内部的各类数据库对象,比如表,索引,序列,存储过程等,而且可以方便的倒出DDL语句和进行各种修改,重建工作。定位到某一类对象上,这列对象允许的操作都会自动列...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥...
密钥 Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存...
密钥 Java生成密钥、保存密钥的实例源码,通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存...
12. 如果导入的是图像序列中的一个picture001.bmp 文件,并且序列中的其他文件位于相同的 文件夹中,则将被识别为图像序列将是下面哪些: □ A. picture001.bmp □ B. picture002.bmp □ C. picture003.bmp □ D. ...
a) 有状态会话Bean的状态是借助于序列化保存下来的 b) 有状态会话Bean被激活后会恢复挂起前的状态 c) 无状态会话Bean不能有属性 d) 有状态会话Bean的所有属性在挂起的时候都会被保存下来 参考答案 15) 关于EJB...
2.8.2 确定文件大小:filesize() 2.8.3 删除一个文件:unlink() 2.8.4 在文件中定位:rewind()、fseek()和ftell() 2.9 文件锁定 2.10 更好的方式:数据库管理系统 2.10.1 使用普通文件的几个问题 2.10.2 RDBMS...
2.8.2 确定文件大小:filesize() 2.8.3 删除一个文件:unlink() 2.8.4 在文件中定位:rewind()、fseek()和ftell() 2.9 文件锁定 2.10 更好的方式:数据库管理系统 2.10.1 使用普通文件的几个问题 2.10.2 RDBMS...
2.8.2 确定文件大小:filesize() 2.8.3 删除一个文件:unlink() 2.8.4 在文件中定位:rewind()、fseek()和ftell() 2.9 文件锁定 2.10 更好的方式:数据库管理系统 2.10.1 使用普通文件的几个问题 2.10.2 RDBMS是...
【插入Flash动画】:将Flash动画插入工作表中并播放,自动获取Flash大小,可以自定义Flash的大小和位置,Flash动画嵌入工作表中 【提取Flash文件】:将嵌入Excel或者Word中的Flash文件提取出来,保存为Swf文件 【播放...