Java中I/O流之Object流
2024-08-25 05:54:14
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
最新文章
- problems during rovio build
- Oracle学习总结_day05_集合_连接查询
- javax mail网址
- html热力图的操作(点击图片的不同位置操作不同的事件)适合说明文档
- 代码中特殊的注释技术——TODO、FIXME和XXX的用处
- Linux概述
- 【剑指offer 面试题23】从上往下打印二叉树
- vim中编写python代码使用python-mode和syntastic插件时警告(Warning)的消除
- C语言的奇技
- jquery中的ajax方法详解
- 自动开机和自动关机设定方法(包括linux和windows)
- 服务器之间socket传输单链接和多连接测试结果
- css流式和弹性布局(未完)
- [Head First Python]5. 推导数据:处理数据
- js中document.write()使用方法
- 04_关于元数据,ResultSetMetaData对象以及API方法介绍
- delphi fastreport 动态加载图片
- 一个简单的加载动画,js实现
- matlab中如何将视频保存成图像
- float和position的使用