zoukankan      html  css  js  c++  java
  • Java中I/O流之Object流

    Java 中的 object 流:直接将 Object 对象写入或读出

      1. serializable 接口:序列化,可以被序列化的,若确实需要将某个类的对象写在硬盘上或网络上,想把他们序列化成一个字节流,就必须实现这个这个接口(标记性接口, 用来标记一下,这个类的对象可以被序列化,那么这个类到底是怎么被序列化的,自己不能控制,是 JDK 直接帮你控制这个类的对象的序列化过程).

      2. transient 关键字:用来修饰成员变量

      3. externalizable 接口:通过 readExternal()、 writeExternal() 这个两个方法,自己实现序列化过程.

    Demo_1:

    import java.io.*;
    class TT implements Serializable { // 尽管没有重写任何方法,但是编译器看到这个标记后,就知道这个类可以被序列化
    	int i = 10;
    	int j = 9;
    	double d = 2.3;
    	int k1 = 15;
    	transient int k2 = 15; // 相当于这个K2是透明的,在序列化的时候不予考虑,也只是往硬盘上写的时候,不写K2的值,读出来就是默认值0
    }
    class Test {
    	public static void main(String[] args) {
    		TT tt = new TT();
    		tt.k1 = 8;
    		try {
    			FileOutputStream fos = new FileOutputStream("E:/eclipse projiect/TEST0505.txt");
    			ObjectOutputStream oos = new ObjectOutputStream(fos);
    			oos.writeObject(tt);
    			oos.flush();
    			oos.close();
    			FileInputStream fis = new FileInputStream("E:/eclipse projiect/TEST0505.txt");
    			ObjectInputStream ois = new ObjectInputStream(fis);
    			TT ttRead = (TT)ois.readObject(); // 读出来的是Object类型,需要强制转换为TT类型
    			System.out.println(ttRead.i+" "+ttRead.j+" "+ttRead.d+" "+ttRead.k1+" "+ttRead.k2);
    		} catch (FileNotFoundException e) {
    			e.printStackTrace();
    		} catch (IOException e){
    			e.printStackTrace();
    		} catch (ClassNotFoundException e){
    			e.printStackTrace();
    		}
    	}
    }
    

    运行结果:10 9 2.3 8 0

    TEST0505.txt 文件中的内容是:� sr TT(岷嗄? D dI iI jI k1xp@ffffff  
           

  • 相关阅读:
    Gin 使用 websocket
    7天用Go从零实现Web框架Gee教程
    docker-compose 搭建 Redis Sentinel 测试环境
    关闭禁用 Redis 危险命令
    Redis Cluster 设置密码
    使用 twine 上传自己的 python 包到 pypi
    Redis 5.0.7 讲解,单机、集群模式搭建
    Redis 单机模式,主从模式,哨兵模式(sentinel),集群模式(cluster),第三方模式优缺点分析
    django 重写 mysql 连接库实现连接池
    编译安装httpd-2.4
  • 原文地址:https://www.cnblogs.com/bosongokay/p/6802447.html
Copyright © 2011-2022 走看看