Java IO--数据操作流DataOutputStream/DataInputStream

简介: <h1>数据操作流:</h1> <div><span style="font-size:18px">与平台无关的数据操作流:DataOutputStream、DataInputStream</span></div> <div><img src="http://img.blog.csdn.net/20131112084311390" alt=""><br></div> <div>如

数据操作流:

与平台无关的数据操作流:DataOutputStream、DataInputStream

如果要想使用数据操作流,则肯定要由用户自己指定数据的保存格式,必须按指定好的格式保存数据,才可以使用数据输入流将数据读取进来。

DataOutputStream:


DataOutput接口定义了一系列的writeXxx()的操作,可以写入各种数据类型的数据。
要想使用DataOutputStream写入数据的话,则必须指定好数据的输出格式。

每一行的数据,通过“\n”完结,每行中的各个数据之间通过“\t”完结。
import java.io.DataOutputStream ;
import java.io.File ;
import java.io.FileOutputStream ;
public class DataOutputStreamDemo{
	public static void main(String args[]) throws Exception{	// 所有异常抛出
		DataOutputStream dos = null ;			// 声明数据输出流对象
		File f = new File("d:" + File.separator + "order.txt") ; // 文件的保存路径
		dos = new DataOutputStream(new FileOutputStream(f)) ;	// 实例化数据输出流对象
		String names[] = {"衬衣","手套","围巾"} ;	// 商品名称
		float prices[] = {98.3f,30.3f,50.5f} ;		// 商品价格
		int nums[] = {3,2,1} ;	// 商品数量
		for(int i=0;i<names.length;i++){	// 循环输出
			dos.writeChars(names[i]) ;	// 写入字符串
			dos.writeChar('\t') ;	// 写入分隔符
			dos.writeFloat(prices[i]) ; // 写入价格
			dos.writeChar('\t') ;	// 写入分隔符
			dos.writeInt(nums[i]) ; // 写入数量
			dos.writeChar('\n') ;	// 换行
		}
		dos.close() ;	// 关闭输出流
	}
};
使用DataOutputStream写入的数据要使用DataInputStream读取进来。
import java.io.DataInputStream ;
import java.io.File ;
import java.io.FileInputStream ;
public class DataInputStreamDemo{
	public static void main(String args[]) throws Exception{	// 所有异常抛出
		DataInputStream dis = null ;		// 声明数据输入流对象
		File f = new File("d:" + File.separator + "order.txt") ; // 文件的保存路径
		dis = new DataInputStream(new FileInputStream(f)) ;	// 实例化数据输入流对象
		String name = null ;	// 接收名称
		float price = 0.0f ;	// 接收价格
		int num = 0 ;	// 接收数量
		char temp[] = null ;	// 接收商品名称
		int len = 0 ;	// 保存读取数据的个数
		char c = 0 ;	// '\u0000'
		try{
			while(true){
				temp = new char[200] ;	// 开辟空间
				len = 0 ;
				while((c=dis.readChar())!='\t'){	// 接收内容
					temp[len] = c ;
					len ++ ;	// 读取长度加1
				}
				name = new String(temp,0,len) ;	// 将字符数组变为String
				price = dis.readFloat() ;	// 读取价格
				dis.readChar() ;	// 读取\t
				num = dis.readInt() ;	// 读取int
				dis.readChar() ;	// 读取\n
				System.out.printf("名称:%s;价格:%5.2f;数量:%d\n",name,price,num) ;
			}
		}catch(Exception e){}
		dis.close() ;
	}
};




目录
相关文章
|
1月前
|
存储 Java 数据处理
|
30天前
Mybatis+mysql动态分页查询数据案例——分页工具类(Page.java)
Mybatis+mysql动态分页查询数据案例——分页工具类(Page.java)
21 1
|
1月前
|
存储 Java
JAVA字符串与其他类型数据的转换
JAVA字符串与其他类型数据的转换
27 4
|
30天前
Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
15 1
|
19天前
|
存储 Java
探索 Java IO 流的多种实现方式
【4月更文挑战第4天】Java IO 流是处理输入输出的关键组件,包括文件流(FileInputStream/FileOutputStream)、字符流(FileReader/FileWriter)、缓冲区流(BufferedInputStream/BufferedOutputStream)、转换流(InputStreamReader/OutputStreamWriter)、数据流(DataInputStream/DataOutputStream)、对象流(ObjectInputStream/ObjectOutputStream)、随机访问文件流(RandomAccessFile)和管道流。
|
1月前
|
Java 关系型数据库 MySQL
Flink1.18.1和CDC2.4.1 本地没问题 提交任务到服务器 报错java.lang.NoClassDefFoundError: Could not initialize class io.debezium.connector.mysql.MySqlConnectorConfig
【2月更文挑战第33天】Flink1.18.1和CDC2.4.1 本地没问题 提交任务到服务器 报错java.lang.NoClassDefFoundError: Could not initialize class io.debezium.connector.mysql.MySqlConnectorConfig
49 2
|
1月前
|
缓存 NoSQL Java
java中复杂业务情况下的集合操作(增减集合同步数据)
java中复杂业务情况下的集合操作(增减集合同步数据)
27 0
|
1月前
|
网络协议 Java
Java——UDP数据报
Java——UDP数据报
12 0
|
1月前
|
Java API
java中IO与NIO有什么不同
java中IO与NIO有什么不同
|
3月前
|
存储 Java 数据安全/隐私保护
从零开始学习 Java:简单易懂的入门指南之IO字符流(三十一)
从零开始学习 Java:简单易懂的入门指南之IO字符流(三十一)