DataInputStream和DataOutputStream用于Java基本数据类型跨平台读写,通过包装字节流实现机器无关的数据序列化。先创建FileOutputStream并用DataOutputStream包装,调用writeInt、writeDouble、writeBoolean、writeUTF等方法写入数据;读取时用FileInputStream和DataInputStream按相同顺序调用对应read方法还原数据,需确保读写顺序一致,适合小规模结构化数据传输与存储。
在Java中,DataInputStream 和 DataOutputStream 是处理基本数据类型和字符串的便捷工具。它们属于数据流类库,允许你以机器无关的方式读写Java基本数据类型(如int、double、boolean等),常用于序列化简单数据或在网络、文件传输中保持数据兼容性。
DataInputStream 和 DataOutputStream 并不直接操作文件或网络,而是“包装”已有的字节流(如FileOutputStream、ByteArrayOutputStream等),提供按
数据类型读写的能力。
核心优势是:写入的数据可以被另一个Java程序准确读取,不受平台字节序影响。例如,在一个系统上写入的int值,在其他系统上也能正确还原。
要将基本类型数据写入文件,需将DataOutputStream包装在FileOutputStream之上:
示例代码:
try (DataOutputStream dos = new DataOutputStream(new FileOutputStream("data.dat"))) {读取时必须严格按照写入的顺序和类型进行,否则会抛出EOFException或得到错误数据:
示例代码:
try (DataInputStream dis = new DataInputStream(new FileInputStream("data.dat"))) {实际使用中需注意以下几点:
基本上就这些。Data流简单高效,适合配置数据、小型记录的持久化或跨平台通信场景。