作用: 没有implements Serializable,你就不能通过rmi(包括ejb)提供远程调用。 serialization 允许你将实现了Serializable接口的对象转换为字节序列,这些字节序列可以被完全存储以备以后重新生成原来的对象。 serialization不但可以在本机做,而且可以经由网络操作(就是猫小说的RMI)。这个好处是很大的----因为它自动屏蔽了操作系统的差异,字节顺序等。比如,在Window平台生成一个对象并序列化之,然后通过网络传到一台Unix机器上,然后可以在这台Unix机器上正确地重构这个对象。 Object serialization主要用来支持2种主要的特性: 1。Java的RMI(remote method invocation).RMI允许象在本机上一样操作远程机器上的对象。当发送消息给远程对象时,就需要用到serializaiton机制来发送参数和接收返回直。 2。Java的JavaBeans. Bean的状态信息通常是在设计时配置的。Bean的状态信息必须被存起来,以便当程序运行时能恢复这些状态信息。这也需要serializaiton机制。 总之如果在网络的环境下做类传输,应该还是implements Serializable。 例子: import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; import java.net.ServerSocket; import java.net.Socket; //定义序列化(object) class Student implements Serializable { private int sno; private String sname; public Student(int sno, String sname) { this.sno = sno; this.sname = sname; } public int getSno() { return sno; } public void setSno(int sno) { this.sno = sno; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } @Override public String toString() { return "学号:" + sno + ";姓名:" + sname; } } //(object)的反序列化过程 class MyClient extends Thread { @Override public void run() { try { Socket s = new Socket("localhost", 9999); ObjectInputStream ois = new ObjectInputStream(s.getInputStream()); Student stu = (Student) ois.readObject(); System.out.println("客户端程序收到服务器端程序传输过来的学生对象>> " + stu); ois.close(); s.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } //(object)的序列化过程 class MyServer extends Thread { @Override public void run() { try { ServerSocket ss = new ServerSocket(9999); Socket s = ss.accept(); ObjectOutputStream ops = new ObjectOutputStream(s.getOutputStream()); Student stu = new Student(1, "赵本山"); ops.writeObject(stu); ops.close(); s.close(); ss.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } //测试 public class TestTransfer { public static void main(String[] args) { new MyServer().start(); new MyClient().start(); } } 参照这个例子就会很好的理解Serializable接口的用法和作用了。 版权声明:本文为博主原创文章,未经博主允许不得转载。
相关推荐
例如,在上面的例子中,我们定义了一个User类,并实现了Serializable接口,其中包括一个固定的serialVersionUID变量: public class User implements Serializable { private static final long serialVersionUID ...
在这个例子中,`Animal`接口定义了两个方法:`eat()` 和 `sleep()`。任何实现`Animal`接口的类都必须提供这两个方法的实现。 接下来,我们可以创建一个实现接口的类,例如`Dog`: ```java public class Dog ...
在Java中,如果一个类需要支持序列化,那么这个类就需要实现`java.io.Serializable`接口,尽管该接口没有任何方法需要实现,但它的存在就标志着这个类的对象可以被序列化。 首先,我们来看一下`SerializableDemo`这...
以上只是Java编程中的一部分关键知识点,实际的“java例子”压缩包中可能包含更多具体的示例,如文件操作、网络编程、GUI设计等。通过学习这些例子,初学者可以更好地理解和应用上述概念,逐步成长为熟练的Java...
在Java编程语言中,"导出例子"通常指的是将数据或程序结果输出到文件、数据库或其他存储媒介的过程。这涉及到I/O(输入/输出)操作,是Java开发中不可或缺的一部分。下面我们将深入探讨Java导出数据的相关知识点。 ...
可以创建一个版本类,包含版本号、发布日期等信息,并使用序列化技术(如`java.io.Serializable`接口)将其保存到本地文件,以便下次启动时读取。 在实际开发中,自动更新系统可能还需要考虑更多的细节,比如错误...
虽然枚举不能作为其他类的父类,但它们默认继承了 `java.lang.Enum` 类,这意味着枚举实例可以使用 `Comparable` 和 `Serializable` 接口的方法。 此外,枚举可以实现接口,这使得它们可以具有自定义的行为。例如:...
在Java中,克隆操作是通过实现`Cloneable`接口和重写`Object`类的`clone()`方法来完成的。但需要注意的是,`clone()`方法默认执行的是浅克隆,因此如果对象中包含对其他对象的引用,这些引用不会被复制。为了实现...
Java中的序列化机制有两种实现方式: 一种是实现Serializable接口 另一种是实现Externalizable接口 区别: 实现Serializable接口 1 系统自动储存必要的信息 2 Java内建支持,易于实现,只需实现该接口即可,无须任何...
在这个"java web 主流框架整合开发jsp+javabean例子"中,我们将探讨如何使用JSP(JavaServer Pages)和JavaBean进行前端展示及数据封装,以及如何整合主流的Java Web框架来提升开发效率和应用性能。 首先,JSP是...
1. **远程接口(Remote Interface)**:这是定义远程方法的Java接口。它声明了客户端可以调用的那些方法,这些方法将在服务器端执行。远程接口需要继承`java.rmi.Remote`接口,并且其方法可能会抛出`java.rmi....
Java中的`Serializable`接口可以实现对象的序列化,实现数据备份和恢复。 19. **状态模式**:允许对象在其内部状态改变时改变它的行为,对象看起来好像修改了它的类。Java中Socket的连接状态管理就是状态模式的应用...
Serializable有一个子接口Externalizable,实现Externalizable接口的类可以自行控制对象序列化荷反序列化过程。 一般来说,没有必要自己实现序列化接口,直接交给Java虚拟机是上策。 实现了序列化接口的类,如果...
在Java中,实现`Serializable`接口的类可以被序列化。然而,有时我们可能希望在序列化过程中忽略某些敏感或临时的成员变量。这就是`transient`关键字的用途。 `transient`关键字用于标记某个成员变量,使其在序列化...
Java中的序列化与反序列化是Java编程语言中用于处理对象状态持久化和网络传输的重要技术。序列化是指将一个Java对象转换为字节流的过程,这样就可以将对象的状态保存到磁盘上或者通过网络传输。反序列化则是将字节流...
在这个例子中,`LoggingInfo`类包含了用户的登录信息,包括登录日期、用户ID和密码。由于密码通常是敏感信息,我们不希望它在序列化和反序列化过程中被保留。因此,我们使用`transient`关键字修饰`pwd`变量。这样,...
在Java编程语言中,输入输出(I/O)流是处理数据传输的核心机制,尤其是在文件操作、网络通信和数据管道等方面。本章节将深入探讨《Java语言程序设计》中关于第6章输入输出流的知识点,结合提供的源代码文件,我们...
在这个例子中,我们期望读取的是一个`List<Student>`对象,因此我们需要进行类型转换。 序列化和反序列化对于Java开发者来说是必备技能,因为它允许我们将对象持久化到磁盘或者在网络中传输。然而,需要注意的是,...
通过学习和实践这些Java I/O的例子,开发者可以更好地理解和掌握如何在Java程序中有效地处理数据的输入和输出。对于初学者来说,理解并熟练运用这些基础知识是至关重要的,因为无论是在日常开发还是面试中,I/O编程...