什么是序列化
java中的序列化(serialization)机制能够将一个实例对象的状态信息写入到一个字节流中,使其可以通过socket进行传输、或者持久化存储到数据库或文件系统中;然后在需要的时候,可以根据字节流中的信息来重构一个相同的对象。序列化机制在java中有着广泛的应用,EJB、RMI等技术都是以此为基础的。
正确使用序列化机制
一般而言,要使得一个类可以序列化,只需简单实现java.io.Serializable接口即可(还要实现无参数的构造方法)。该接口是一个标记式接口,它本身不包含任何内容,实现了该接口则表示这个类准备支持序列化的功能。如下例定义了类Person,并声明其可以序列化。
java中的序列化(serialization)机制能够将一个实例对象的状态信息写入到一个字节流中,使其可以通过socket进行传输、或者持久化存储到数据库或文件系统中;然后在需要的时候,可以根据字节流中的信息来重构一个相同的对象。序列化机制在java中有着广泛的应用,EJB、RMI等技术都是以此为基础的。
正确使用序列化机制
一般而言,要使得一个类可以序列化,只需简单实现java.io.Serializable接口即可(还要实现无参数的构造方法)。该接口是一个标记式接口,它本身不包含任何内容,实现了该接口则表示这个类准备支持序列化的功能。如下例定义了类Person,并声明其可以序列化。
- public class Person implements Serializable {
- private static final long serialVersionUID = 1L;
- private String name;;
- private int age;
- public Person(){
- }
- public Person(String str,int n){
- System.out.println("Inside Person's Constructor");
- name = str;
- age = n;
- }
- public String getName() {
- return name;
- }
- public int getAge() {
- return age;
- }
- }
下面为三种格式转换的代码:
1.默认格式.
- public class SerializeToFlatFile {
- public static void main(String[] args) {
- SerializeToFlatFile ser = new SerializeToFlatFile();
- ser.savePerson();
- ser.restorePerson();
- }
- public void savePerson(){
- Person myPerson = new Person("Jay", 24);
- try{
- FileOutputStream fos = new FileOutputStream("E:\\person.txt");
- ObjectOutputStream oos = new ObjectOutputStream(fos);
- System.out.println("Person--Jay,24---Written");
- oos.writeObject(myPerson);
- oos.flush();
- oos.close();
- }catch(Exception e){
- e.printStackTrace();
- }
- }
- @SuppressWarnings("resource")
- public void restorePerson(){
- try{
- FileInputStream fls = new FileInputStream("E:\\person.txt");
- ObjectInputStream ois = new ObjectInputStream(fls);
- Person myPerson = (Person)ois.readObject();
- System.out.println("\n---------------------\n");
- System.out.println("Person --read:");
- System.out.println("Name is:"+myPerson.getName());
- System.out.println("Age is :"+myPerson.getAge());
- }catch(Exception e){
- e.printStackTrace();
- }
- }
- }
输出结果: sr test.serializable.Person I ageL namet Ljava/lang/String;xp t Jay
2.XML格式
- //参考:http://www.cnblogs.com/bluesky5304/archive/2010/04/07/1706061.html
- public class SerializeXML {
- public static void main(String[] args) {
- SerializeXML ser = new SerializeXML();
- ser.serializeToXml();
- ser.deSerializeFromXml();
- }
- public void serializeToXml(){
- Person[] myPersons = new Person[2];
- myPersons[0] = new Person("Jay", 24);
- myPersons[1] = new Person("Tom", 23);
- XStream xStream = new XStream();
- xStream.alias("Person", Person.class);
- try{
- FileOutputStream foStream = new FileOutputStream("E:\\persons.xml");
- xStream.toXML(myPersons,foStream);
- }catch(Exception e){
- e.printStackTrace();
- }
- }
- public void deSerializeFromXml(){
- XStream xStream = new XStream();
- xStream.alias("Person", Person.class);
- Person[] myPersons = null;
- try{
- FileInputStream flStream = new FileInputStream("E:\\persons.xml");
- myPersons = (Person[])xStream.fromXML(flStream);
- if(myPersons!=null){
- for(Person person:myPersons){
- System.out.println(person.getName());
- System.out.println(person.getAge());
- }
- }
- }catch(Exception e){
- e.printStackTrace();
- }
- }
- }
输出结果:
- <Person-array>
- <Person>
- <name>Jay</name>
- <age>24</age>
- </Person>
- <Person>
- <name>Tom</name>
- <age>23</age>
- </Person>
- </Person-array>
3.JSON格式
- //参考:http://www.cnblogs.com/hoojo/archive/2011/04/22/2025197.html
- public class SerializeJSON {
- public static void main(String[] args) {
- SerializeJSON serializeJSON = new SerializeJSON();
- serializeJSON.writeJSON();
- serializeJSON.readJSON();
- }
- public void writeJSON(){
- XStream xStream = new XStream(new JettisonMappedXmlDriver());
- Person person = new Person("geniushehe", 16);
- try {
- FileOutputStream fos = new FileOutputStream("E:\\json.js");
- xStream.setMode(XStream.NO_REFERENCES);
- xStream.alias("Person", Person.class);
- xStream.toXML(person, fos);
- } catch (FileNotFoundException e) {
- e.printStackTrace();
- }
- }
- public void readJSON(){
- XStream xStream = new XStream(new JettisonMappedXmlDriver());
- Person person = null;
- try {
- FileInputStream fis = new FileInputStream("E:\\json.js");
- xStream.setMode(XStream.NO_REFERENCES);
- xStream.alias("Person", Person.class);
- person = (Person)xStream.fromXML(fis);
- System.out.println(person.getName());
- System.out.println(person.getAge());
- } catch (FileNotFoundException e) {
- e.printStackTrace();
- }
- }
- }
输出结果:
- {"Person":{"name":"geniushehe","age":16}}
相关推荐
它比XML、JSON等格式更小巧、高效,同时提供了编译器来生成对应语言的存取代码,使得数据序列化和反序列化过程更加便捷。 标题中的"protobuf 反序列化工具"指的是一个专门处理protobuf序列化数据的程序,能够将...
3. **FST(Fast-Serialization)序列化**:FST是另一种高效序列化库,它的性能优于Java序列化和Kryo,同时提供了更好的反序列化安全性和较小的字节流。 4. **JSON序列化**:通过将对象转化为JSON字符串,可以在多个...
在C#编程中,序列化是一个非常重要的概念,它允许我们将对象的状态转化为可存储或可传输的数据格式,如XML、JSON或二进制。在某些场景下,我们可能需要在一个文件中存储多个序列化的对象,这可以有效地节省磁盘空间...
在本文中,我们将深入探讨如何将Spring框架与Redis集成,特别是在非集群环境下,结合Spring的Template和连接池,以及使用JSON和JDK序列化技术。首先,我们需要理解Spring的RedisTemplate,它是一个强大的工具,允许...
序列化是指将数据结构或对象的状态转换为可存储或传输的形式,例如XML、JSON或二进制格式。在画图程序中,序列化可能用于保存用户的画图操作历史,以便后续打开程序时能恢复到之前的状态。这通常涉及到自定义序列化...
Flatbuffers是一种高效的序列化库,由Google开发,主要用于游戏开发、数据分析和其他需要快速存取大量数据的应用场景。它的主要特点是允许直接在内存中访问序列化后的数据,无需像JSON或XML那样进行解码,从而极大地...
- FsPickler设计时考虑了性能,特别是在二进制和JSON格式上,能够提供比默认.NET序列化器更快的速度。 - 这对于大数据处理、网络通信和持久化存储等场景尤其重要,因为快速的序列化可以显著提高整体系统效率。 3....
1. **什么是序列化与反序列化**:序列化是将数据结构转换为可持久化或可传输的格式,如JSON、XML或二进制格式;反序列化则是相反的过程,将这些格式的数据恢复为原来的对象。在分布式系统、网络通信和持久化存储等...
protobuf序列化的优势在于它具有高度的效率和紧凑性,相比JSON或XML等文本格式,protobuf生成的二进制数据占用的空间更小,解析和生成的速度更快。此外,protobuf提供了向前和向后的兼容性,使得升级数据结构时能更...
通过使用这个转换模块,开发者可以方便地在易语言中处理XML数据,实现数据的存取、交换和序列化。对于处理XML的易语言程序来说,这样的模块无疑大大提高了开发效率和代码的可维护性。在实际项目中,可以根据具体需求...
常见的持久化方法有多种,例如JSON、XML序列化、数据库存储以及特定的文件格式如二进制文件。在这个场景下,由于提到的是“写入文件”,我们可能会使用序列化技术。序列化是将对象转换为字节流的过程,而反序列化则...
这种序列化方法比XML、JSON等格式更紧凑、更快,特别适合在网络通信和存储中使用。 在给定的压缩包中,`protoc.exe`是protobuf的编译器,用于将.proto文件转换为不同编程语言的源代码。通过运行这个编译器,你可以...
5. **解析与序列化**:Json可以被解析成编程语言中的数据结构,反之也可以将数据结构序列化为Json字符串,便于在网络间传输。 通过以上介绍,你应该对Map转Json以及Json的基本概念有了初步理解。在实际开发中,正确...
Protocol Buffers是一种高效的数据序列化协议,它允许开发者定义数据结构的模式,然后将这些模式转换为各种语言的存取代码,如Java、C++或Python。 **Protocol Buffers基本概念:** 1. **数据模式(.proto文件)**...
1. JSON序列化:将自定义对象转换为JSON格式的字符串,然后存储这个字符串。Android提供了Gson库,它能方便地将Java对象转换为JSON字符串,反之亦然。首先,你需要在项目中引入Gson库,然后创建一个Gson实例,将对象...
6. **序列化工具**:库内置了对 XML、JSON 和 YAML 数据格式的序列化支持,方便数据交换和存储。 7. **数据库集成**:Korio 集成了 Redis、Cassandra 和 ElasticSearch,为这些流行数据库提供了便捷的异步操作API,...
`mutationToDom`用于将块的转换状态序列化到XML元素中,而`domToMutation`则是反序列化过程,从XML中恢复块的转换状态。这样,当块被保存、加载、复制或粘贴时,其转换状态能够得以保留。 例如,假设我们有一个数学...
另外,Java提供了一种叫做序列化(Serialization)的机制,允许对象的状态被转换为字节流,然后保存到磁盘或通过网络传输。要实现序列化,类必须实现Serializable接口。序列化可以保存对象的完整状态,但不适用于...
Protocol Buffer是Google开发的一种高效、灵活且跨平台的数据序列化协议,用于结构化数据的序列化,类似于XML、JSON,但更小、更快、更简单。它能够将结构化的数据序列化,可用于数据存储、通信协议等方面。Protocol...
protobuf-2.5.0是Google开发的一种高效、灵活的数据序列化协议,全称为Protocol Buffers。这个版本的下载提供了一个方便的方式,让开发者能够直接获取并安装这一强大的工具,同时还附带了安装教程,帮助用户顺利进行...