Java的"对象序列化"能让你将一个实现了Serializable接口的对象转换成一组byte,这样日后要用这个对象时候,你就能把这些byte数据恢复出来,并据此重新构建那个对象了。这一点甚至在跨网络的环境下也是如此,这就意味着序列化机制能自动补偿操作系统方面的差异。也就是说,你可以在Windows机器上创键一个对象,序列化之后,再通过网络传到Unix机器上,然后在那里进行重建。你不用担心在不同的平台上数据是怎样表示的,byte顺序怎样,或者别的什么细节。
对象序列化本身就非常有趣,因为它能让你实现"轻量级的persistence(lightweight persistence)"。所谓persistence是指,对象的生命周期不是由程序是否运行决定的;在程序的两次调用之间对象仍然还活着。通过"将做过序列化处理的对象写入磁盘,等到程序再次运行的时候再把它读出来",你可以达到persistence的效果。之所以说"轻量级",是因为你不能用像"persistent"这样的关键词来直接定义一个对象,然后让系统去处理所有细节(虽然将来有可能会这样)。相反,你必须明确地进行序列化(serialize)和解序列化(deserialize)。如果你需要更为正式的persistence功能,可以考虑Java Data Object( 简称是JDO)或Hibernate之类的工具(http://hibernate.sourceforge.net)。
之所以要在语言里加入对象序列化是因为要用它来实现两个重要的功能。Java的远程方法调用(Remote Method Invocation简称RMI)能让你像调用自己机器上的对象那样去调用其它机器上的对象。当你向远程对象传递消息的时候,就需通过对象序列化来传送参数和返回值了。RMI会在Thinking in Enterprise Java作讨论。
我们会在第14章讲到JavaBean。对JavaBean来说,对象序列化也是必不可少的。Bean的状态信息通常是在设计时配置的。这些状态信息必须保存起来,供程序启动的时候用;对象序列化就负责这个工作。
序列化一个对象还是比较简单的,只要让它实现Serializable接口就行了(这是一个"标记接口(tagging interface)",没有任何方法)。但是,当语言引入序列化概念之后,它的很多标准类库的类,包括primitive的wrapper类,所有的容器类,以及别的很多类,都会相应地发生改变。甚至连Class对象都会被序列化。
要想序列化对象,你必须先创建一个OutputStream,然后把它嵌进ObjectOutputStream。这时,你就能用writeObject( )方法把对象写入OutputStream了。读的时候,你得把InputStream嵌到ObjectInputStream里面,然后再调用readObject( )方法。不过这样读出来的,只是一个Object的reference,因此在用之前,还得先下传。
对象序列化最聪明的一点是,它不仅能保存对象的副本,而且还会跟着对象里面的reference,把它所引用的对象也保存起来,然后再继续跟踪那些对象的reference,以此类推。这种情形常被称为"单个对象所联结的'对象网'"。这个机制所涵盖的范围不仅包括对象的成员数据,而且还包含数组里面的reference。如果你要自己实现对象序列化的话,那么编写跟踪这些链接的程序将会是一件非常痛苦的任务。但是,Java的对象序列化就能精确无误地做到这一点,毫无疑问,它的遍历算法是做过优化的。
分享到:
相关推荐
实现 JavaBean 持久化有多种方式,其中最常见的是使用 Java 的序列化机制。序列化是将 Java 对象转换为字节流的过程,这样就可以将对象的状态保存到文件或数据库中,或者在网络上传输。 #### 示例代码 ```java ...
- **序列化支持**:JavaBean可以通过实现`Serializable`接口来支持序列化,以便持久化对象状态。 2. **JavaBean在数据库操作中的应用** - **数据访问对象(DAO)模式**:JavaBean常被用于实现DAO层,提供对数据库...
4. **序列化**:如果需要持久化JavaBean,它应该实现`Serializable`接口。 在投票系统中,我们可以识别出以下几个关键的JavaBean组件: 1. **VoteBean**:这个Bean可能代表一次具体的投票,包含了投票的题目、选项...
此外,Java Bean还可以实现Serializable接口,以便进行持久化存储。 在描述中提到的"将逻辑封装到bean中",是指将数据库操作相关的业务逻辑放入Java Bean中。这样做的好处是提高了代码的可读性和可维护性,使得前端...
4. 为了让其他组件可以识别和使用JavaBean,可以实现Serializable接口,使其可序列化。 JavaBean的注解: Java 5引入了注解(Annotation),使得JavaBean的创建更加简洁。例如,使用`@BeanProperties`可以自动生成...
要使一个Java类成为可序列化的,只需在类定义上添加`java.io.Serializable`接口。序列化后,可以使用`ObjectOutputStream`将JavaBean写入文件,用`ObjectInputStream`从文件读取。 XML持久化则是将Java对象转换为...
3. **序列化**:实现Serializable接口,使Bean对象能被持久化或者在网络间传输。 在本项目中,JavaBean将用于封装留言的信息,比如用户名、留言内容和时间戳。例如,我们可以创建一个名为`MessageBean`的Java类,...
4. **序列化**:许多JavaBean需要实现Serializable接口,以便于持久化或在网络中传输。 5. **属性事件**:JavaBean可以包含属性更改事件(PropertyChangeSupport)和事件监听器,允许在属性更改时通知其他组件。 在...
- **序列化**:为了能在网络上传输或持久化,JavaBean通常实现`Serializable`接口。 - **命名规则**:属性、getter和setter方法的命名应遵循驼峰命名法,如属性`name`对应getter方法`getName()`和setter方法`set...
3. **序列化**:Java Bean需要实现`Serializable`接口,这样它就可以被序列化和反序列化,用于持久化存储或网络传输。 4. **属性通知**:Bean可以包含`PropertyChangeSupport`类的实例,用于支持属性变化的通知机制...
- **可序列化**:为了支持跨网络的传输和持久化存储,JavaBean需要实现Serializable接口。 - **无状态**:理想情况下,JavaBean在服务器端是无状态的,即它们不保存会话信息,这样可以提高服务器性能和可伸缩性。 ...
JavaBean遵循一定的设计原则,包括公有构造函数、公有属性(getter和setter方法)以及实现Serializable接口以支持序列化。在JSP中,我们可以直接通过id属性引用JavaBean,然后通过属性访问器(getters和setters)...
4. **序列化**:许多JavaBean实现了Serializable接口,这使得对象可以被序列化,即转换为字节流,便于持久化或在网络间传输。 JavaBean在Web开发中的应用: 1. **视图层(View)**:在JSP(JavaServer Pages)中,...
4. **序列化**:JavaBean可以通过实现Serializable接口来支持序列化,这使得对象的状态可以保存到磁盘或在网络上传输。 5. **可读性**:JavaBean的代码应具有良好的可读性,便于理解和维护。 在这个简单的airline...
3. **序列化:** JavaBean可能需要实现`Serializable`接口,以便持久化或跨网络传输。 **JSP与JavaBean结合:** 1. **实例化JavaBean:** 在JSP中,可以使用`<jsp:useBean>`标签来实例化JavaBean,如`...
- **可序列化(Serializable)**:这使得JavaBean可以被持久化,并在网络上传输。 - **具有无参构造函数**:这是JavaBean的基本要求之一,确保可以通过反射等机制创建JavaBean实例。 - **使用get/set方法访问其属性*...
4. **序列化**:如果Bean需要在网络中传输或持久化,那么应该实现`Serializable`接口。 在这个系统中,JavaBean可能用于封装寝室、学生、管理员等实体的数据,通过setter和getter方法设置和获取数据,提供业务逻辑...
3. **序列化**:如果JavaBean需要在网络上传输或者持久化存储,那么应该实现`Serializable`接口。 通过上述介绍可以看出,JavaBean在Java开发中扮演着极其重要的角色,无论是简单的数据封装还是复杂的企业级应用,...
4. **序列化**:为了能在网络中传输或持久化,JavaBean可以实现Serializable接口。 在JSP中使用JavaBean,主要有以下步骤: 1. **创建JavaBean**:编写JavaBean类,例如名为`UserBean`的类,包含姓名和年龄属性,...