• OutputStream和InputStream的区别 + 实现java序列化


    我们所说的流,都是针对内存说的,比如为什么打印到屏幕上就是System.out.println();而从屏幕等待用户输入的却是System.in呢?因为对于内存来说,把字符串打印到屏幕上是从内存流向屏幕这个显示器的,也就是输出,而从屏幕等待用户输入呢?就是等待键盘将字符输入到内存中。

    所以,你根本就不用死记硬背,当你遇到IO的时候,就想两件事,第一,我的内存是中心,第二看看流的方向(矢量)!

    好吧,那么往硬盘上写文件是out还是in呢?别一看到“写”文件你就说in,那是望文生义,你看,写文件的流向,是 内存---------->硬盘 内存为中心,到硬盘,OK 用out 那么就是FileOutputStream、BufferedOutputStream 等等
    那读文件呢?是 内存<---------------硬盘 那么就是in了 , 看清楚数据的流向就OK!

    那我访问网络,看网页是什么呢 网络--------------->内存 是in 因为我们访问页面是要抓取该页面得一个html文件,那我要是在网络上输入帐号密码登陆呢? 是不是内存的东西要写到该服务器上呢,所以当然是out了!

    同样socket编程用到更多的IO,这里分别用Server(服务器端)和Client(客户端)来说明

    Server: 遇到请求,网络----->内存 IN                                            服务器应答, 内存------->网络 OUT
    ----------------------------------------------------------------------------------------------
    Client: 请求服务, 内存----->网络 OUT                                        服务器应答, 网络------->内存 IN

    被搞糊涂了?那么你先别想太多,只是想是内存的数据出去了就是out 外设的东西到内存了就IN了



    Java 串行化技术可以使你将一个对象的状态写入一个Byte 里,并且可以从其它地方把该Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到数据库、文件等系统里。Java的串行化机制是RMI、EJB等技术的技术基础。用途:利用对象的串行化实现保存应用程序的当前工作状态,下次再启动的时候将自动地恢复到上次执行的状态。

    序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决在对对象流进行读写操作时所引发的问题。

    序列化的实现:将需要被序列化的类实现Serializable接口,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。

    2、串行化的特点:

        (1)如果某个类能够被串行化,其子类也可以被串行化。如果该类有父类,则分两种情况来考虑,如果该父类已经实现了可串行化接口。则其父类的相应字段及属性的处理和该类相同;如果该类的父类没有实现可串行化接口,则该类的父类所有的字段属性将不会串行化。

      (2)声明为statictransient类型的成员数据不能被串行化。因为static代表类的状态, transient代表对象的临时数据;

      (3)相关的类和接口:在java.io包中提供的涉及对象的串行化的类与接口有ObjectOutput接口、ObjectOutputStream类、ObjectInput接口、ObjectInputStream类。

        (1)ObjectOutput接口:它继承DataOutput接口并且支持对象的串行化,其内的writeObject()方法实现存储一个对象。ObjectInput接口:它继承DataInput接口并且支持对象的串行化,其内的readObject()方法实现读取一个对象。

        (2)ObjectOutputStream类:它继承OutputStream并且实现ObjectOutput接口。利用该类来实现将对象存储(调用ObjectOutput接口中的writeObject()方法)。ObjectInputStream类:它继承InputStream类并且实现ObjectInput接口。利用该类来实现读取一个对象(调用ObjectInput接口中的readObject()方法)。

      对于父类的处理,如果父类没有实现串行化接口,则其必须有默认的构造函数(即没有参数的构造函数)。否则编译的时候就会报错。在反串行化的时候,默认构造函数被调用。但是若把父类标记为可以串行化,则在反串行化的时候,其默认构造函数不会被调用。这是为什么呢?这是因为Java 对串行化的对象进行反串行化的时候,直接从流里获取其对象数据来生成一个对象实例,而不是通过其构造函数来完成。

    import java.io.*;

    public class Cat implements Serializable {

            private String name;

            public Cat () {

                    this.name = "new cat";

            }

            public String getName() {

                    return this.name;

            }

            public void setName(String name) {

                    this.name = name;

            }

            public static void main(String[] args) {         

                    Cat cat = new Cat();

                    try {

    FileOutputStream获得一个文件流,ObjectOutputStream链接对象和文件流,通过writeObject方法把对象写到硬盘上面,从内存中的对象写到硬盘,故是OUT流

                            FileOutputStream fos = new FileOutputStream("catDemo.out");    

     

                            ObjectOutputStream oos = new ObjectOutputStream(fos);

                            System.out.println(" 1> " + cat.getName());

                            cat.setName("My Cat");                       

                            oos.writeObject(cat);

                            oos.close();                       

                    } catch (Exception ex) {  ex.printStackTrace();   }

                    try {

    把硬盘文件中的对象写到内存,故是IN流

                            FileInputStream fis = new FileInputStream("catDemo.out");

                            ObjectInputStream ois = new ObjectInputStream(fis);

                            cat = (Cat) ois.readObject();

                            System.out.println(" 2> " + cat.getName());

                            ois.close();

                    } catch (Exception ex) {

                            ex.printStackTrace();

                    }

            }

    }//writeObject和readObject本身就是线程安全的,传输过程中是不允许被并发访问的。所以对象能一个一个接连不断的传过来

     


  • 相关阅读:
    4 weekend110的textinputformat对切片规划的源码分析 + 倒排索引的mr实现 + 多个job在同一个main方法中提交
    3 weekend110的shuffle机制 + mr程序的组件全貌
    2 weekend110的hadoop的自定义排序实现 + mr程序中自定义分组的实现
    1 weekend110的复习 + hadoop中的序列化机制 + 流量求和mr程序开发
    weekend110(Hadoop)的 第四天笔记
    4 weekend110的YARN的通用性意义 + yarn的job提交流程
    3 weekend110的job提交的逻辑及YARN框架的技术机制 + MR程序的几种提交运行模式
    Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.ClassVisitor
    Android SDK 和 Eclipse ADT 离线安装 教程
    leetcode——Evaluate Reverse Polish Notation 求算式值(AC)
  • 原文地址:https://www.cnblogs.com/baoendemao/p/3804797.html
Copyright © 2020-2023  润新知