一 什么叫序列化java
通俗点讲:它是处理对象流的一种机制,便可以很方便的保存内存中java对象的状态,同时也为了方便传输。数据库
二 序列化有什么做用安全
1.方便传输,速度快,还很安全,被调用方序列化,调用方反序列化便可拿到传输前最原始的java对象,经常使用于不一样进程之间的对象传输对象
2.方便存储,无论是存储成文件仍是数据库,都行,存储为文件,下回要用能够直接反序列拿到对象接口
三 怎么序列化和反序列化进程
实现序列化接口就行(里面什么方法都没有,不用管的,只是一个标记接口而已)Serializable;内存
至于他们的代码怎么写,网上例子不少,随便搜一下就好了io
四 序列化时须要注意事项变量
为了避免必要的报错麻烦: 序列化时最好是定义序列化版本id 即 public static final Long seriaVersionUID = 1L (默认) 或者 xxxxx L(自定义64位都行)序列化
由于反序列化会判断序列化中的id和类中的id是否同样,若是不定义虽然会自动生成,但若是后面改了东西列,因此仍是自觉点定义一个id,省去好多麻烦
同时记住静态变量不会被序列化的,它可不在堆内存中,序列化只会序列化堆内存