博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
implements Serializable有什么作用
阅读量:5736 次
发布时间:2019-06-18

本文共 2988 字,大约阅读时间需要 9 分钟。

没有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接口的用法和作用了。

 

转载地址:http://wmrwx.baihongyu.com/

你可能感兴趣的文章
字符串的简单操作
查看>>
C#新功能--命名参数与可选参数
查看>>
strtok和strtok_r
查看>>
维辰超市:借助云商城成功转型新零售
查看>>
web.xml中<load-on-start>n</load-on-satrt>作用
查看>>
python之路---进程
查看>>
1061. Dating (20)
查看>>
leetcode 【 Best Time to Buy and Sell Stock II 】python 实现
查看>>
【算法】CRF
查看>>
windows 8 微软拼音输入法
查看>>
Windows UI风格的设计(7)
查看>>
SQL中使用WITH AS提高性能 使用公用表表达式(CTE)简化嵌套SQL
查看>>
oracle 强行杀掉一个用户连接
查看>>
Git提交本地库代码到远程服务器的操作
查看>>
灾难拯救——让软件项目重回轨道
查看>>
ssh链接git服务器,解决push pull要求输入密码问题
查看>>
Netty 源码解析(二):对 Netty 中一些重要接口和类的介绍
查看>>
mysql中主外键关系
查看>>
第七章:数据字典
查看>>
python 字符串 类型互相转换 str bytes 字符串连接
查看>>