Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7331552
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68080
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 21:47:32

下载本文示例代码
  数据流一般分为输入流(InputStream)和输出流(OutputStream)两种,但是在操作文件时,当向其中写数据时,它就是一个输出流;当从其中读取数据时,它就是一个输入流。当然,键盘只是一个输入流,而屏幕则只是一个输出流。  Java的标准数据流是指在字符方式下(如DOS),程序与系统进行交互的方式,分为三种:   System.in   “标准”输入流。此流已打开并准备提供输入数据。通常,此流对应于键盘输入或者由主机环境或用户指定的另一个输入源。   System.out   “标准”输出流。此流已打开并准备接受输出数据。通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。   System.err   “标准”错误输出流。此流已打开并准备接受输出数据。  通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。按照惯例,此输出流用于显示错误消息,或者显示那些即使用户输出流(变量 out 的值)已经重定向到通常不被连续监视的某一文件或其他目标,也应该立刻引起用户注意的其他信息。   下面以一个例子来说明:用System.in.read(buffer)从键盘输入一行字符,存储在缓冲区buffer中,count保存实际读入的字节个数,再以整数和字符两种方式输出buffer中的值。read方法在java.io包中,而且要抛出IOException异常,我们在这里用try/catch捕捉。程序如下(本例程序放在包biz.1cn.stream里面): package biz.1cn.stream;import java.io.IOException;/*** @author chenrz(simon)* @date 2006-6-29* <p>* 标准数据流例子()* </p>*/public class Input { public static void main(String[] args) {  System.out.println("请输入:");  // 输入缓冲区域  byte buffer[] = new byte[512];  int count;  try {   // 读取标准输入流   count = System.in.read(buffer);   System.out.println("实际读入的字节数目:" count);   System.out.println("输出结果:");   // 直接输出buffer元素值   for (int i = 0; i < count; i ) {    System.out.print(buffer[i] " ");   }   System.out.println();   // 以char方式输出buffer   for (int i = 0; i < count; i ) {    System.out.print((char) buffer[i]);   }  } catch (IOException e) {   e.printStackTrace();  } }}  下面说一下java.io包中的数据流及文件类  InputStream是表示字节输入流的所有类的超类。需要定义InputStream的子类的应用程序必须始终提供返回下一个输入字节的方法,也就是以字节作为基本处理单位。  直接已知子类:  AudioInputStream, ByteArrayInputStream, FileInputStream, FilterInputStream, InputStream, ObjectInputStream, PipedInputStream, SequenceInputStream, StringBufferInputStream   OutputStream是表示输出字节流的所有类的超类。输出流接受输出字节并将这些字节发送到某个接收器,需要定义 OutputStream 子类的应用程序必须始终提供至少一种可写入一个输出字节的方法。  直接已知子类:  ByteArrayOutputStream, FileOutputStream, FilterOutputStream, ObjectOutputStream, OutputStream, PipedOutputStream   Reader用于读取字符流的抽象类。子类必须实现的方法只有 read(char[], int, int) 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。  直接已知子类:  BufferedReader, CharArrayReader, FilterReader, InputStreamReader, PipedReader, StringReader   Writer写入字符流的抽象类。子类必须实现的方法仅有 write(char[], int, int)、flush() 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。  直接已知子类:  BufferedWriter, CharArrayWriter, FilterWriter, OutputStreamWriter, PipedWriter, PrintWriter, StringWriter   数据流一般分为输入流(InputStream)和输出流(OutputStream)两种,但是在操作文件时,当向其中写数据时,它就是一个输出流;当从其中读取数据时,它就是一个输入流。当然,键盘只是一个输入流,而屏幕则只是一个输出流。  Java的标准数据流是指在字符方式下(如DOS),程序与系统进行交互的方式,分为三种:   System.in   “标准”输入流。此流已打开并准备提供输入数据。通常,此流对应于键盘输入或者由主机环境或用户指定的另一个输入源。   System.out   “标准”输出流。此流已打开并准备接受输出数据。通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。   System.err   “标准”错误输出流。此流已打开并准备接受输出数据。  通常,此流对应于显示器输出或者由主机环境或用户指定的另一个输出目标。按照惯例,此输出流用于显示错误消息,或者显示那些即使用户输出流(变量 out 的值)已经重定向到通常不被连续监视的某一文件或其他目标,也应该立刻引起用户注意的其他信息。   下面以一个例子来说明:用System.in.read(buffer)从键盘输入一行字符,存储在缓冲区buffer中,count保存实际读入的字节个数,再以整数和字符两种方式输出buffer中的值。read方法在java.io包中,而且要抛出IOException异常,我们在这里用try/catch捕捉。程序如下(本例程序放在包biz.1cn.stream里面): package biz.1cn.stream;import java.io.IOException;/*** @author chenrz(simon)* @date 2006-6-29* <p>* 标准数据流例子()* </p>*/public class Input { public static void main(String[] args) {  System.out.println("请输入:");  // 输入缓冲区域  byte buffer[] = new byte[512];  int count;  try {   // 读取标准输入流   count = System.in.read(buffer);   System.out.println("实际读入的字节数目:" count);   System.out.println("输出结果:");   // 直接输出buffer元素值   for (int i = 0; i < count; i ) {    System.out.print(buffer[i] " ");   }   System.out.println();   // 以char方式输出buffer   for (int i = 0; i < count; i ) {    System.out.print((char) buffer[i]);   }  } catch (IOException e) {   e.printStackTrace();  } }}  下面说一下java.io包中的数据流及文件类  InputStream是表示字节输入流的所有类的超类。需要定义InputStream的子类的应用程序必须始终提供返回下一个输入字节的方法,也就是以字节作为基本处理单位。  直接已知子类:  AudioInputStream, ByteArrayInputStream, FileInputStream, FilterInputStream, InputStream, ObjectInputStream, PipedInputStream, SequenceInputStream, StringBufferInputStream   OutputStream是表示输出字节流的所有类的超类。输出流接受输出字节并将这些字节发送到某个接收器,需要定义 OutputStream 子类的应用程序必须始终提供至少一种可写入一个输出字节的方法。  直接已知子类:  ByteArrayOutputStream, FileOutputStream, FilterOutputStream, ObjectOutputStream, OutputStream, PipedOutputStream   Reader用于读取字符流的抽象类。子类必须实现的方法只有 read(char[], int, int) 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。  直接已知子类:  BufferedReader, CharArrayReader, FilterReader, InputStreamReader, PipedReader, StringReader   Writer写入字符流的抽象类。子类必须实现的方法仅有 write(char[], int, int)、flush() 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。  直接已知子类:  BufferedWriter, CharArrayWriter, FilterWriter, OutputStreamWriter, PipedWriter, PrintWriter, StringWriter 下载本文示例代码


浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流浅谈Java的标准数据流
阅读(199) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~