Java复习7.输入输出流 20131005

前言:

Java中涉及数据的读写,都是基于流的,这一块的知识相当重要,而且在Java中的数据,char字符是16bit的,所以存在字节流和字符流的区别。如果是字符文件的输入输出,使用字符流(以Reader/Writer为抽象基类),而其他的数据是二进制的,需要使用字节流(以InputStream和OutputStream为抽象基类)。

其实不止文件,网络数据传输也是输入输出流。

目录

1.字节流和字符流... 2

1.1字节输入流:... 2

1.2字节输出流:... 5

2.字符流... 6

2.1字符数据流输入:... 6

2.2字符数据流输出:... 7

3.使用缓冲数据流,提高IO的效率,减少IO的次数... 7

3.1缓冲字节流: 8

3.2缓冲字符流:... 9

为了便于理解,附图一张:

 

1.字节流和字符流

字节流就是数据的基本单位是byte,字符流使用字符组成的,基本单位是char,在Java中char是由两个字节保存的。所有的InputStream/OutputStream的子类都可以用于处理二进制数据,他是按照字节存储的,但是对于字符的文本文件,使用字符流比较好。

首先是字节流,基类是InputStream/OutputStream

1.1字节输入流:

InputStream in = null;

try {

String filePath = ClassLoader.getSystemResource("a.txt").getPath();

System.out.println("FilePath:"+filePath);

/*

* 以字节流的方式打开文件,读取的是一个二进制流 byte[] ,如果不存在该文件,则会抛出异常,FileNotFoundException           *

*/

in = new FileInputStream(filePath);

byte[] buf = new byte[100];

// read file from inputstream

/*

* public int read(); read next byte data, if to the file end return -1;

* public int read(byte[] buf);

* Reads up to b.length bytes of data from this input stream into an array of bytes.

* return the total number of bytes read into the buffer, or -1 if there is no more data

* because the end of the file has been reached.

* we should clear the buf or record the read byte number.

*

*/

if(in != null){

/*

* 比较正规的读取方式,这样每一次获取的是一定字节数的byte,保存在响应的字节中,然后

* 将字节数组转换成String输出结果

*/

/*int read_byte_number = -1;

int count = 0;

while( (read_byte_number = in.read(buf, 0, 100)) != -1){

System.out.print(new String(buf,0,read_byte_number));

count++;

}

System.out.println("count:" + count);

*/

/*

*  在文件中的数据,一个ASCII对应的是一个字节,但是一个汉字或者其他的字符,保存在文件中是两个字节

*  我们读取的时候使用read只是读取的一个字节,所以对于ASCII的字符是可以读取出来的,返回值对应的ASCII的int

*  可以将它转换成相应的char;但是对于汉字是不可以的,每次只是读取的一个字符。

*/

int i = in.read();

System.out.println(i+":" + (char)i);

}

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally{

if(in != null){

try {

in.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

1.2字节输出流:

OutputStream  out = null;

try {

/*

* if the file does not exist, it will create the file

* if the file exists, but append default is false, it will clear the file write new content

* we can use the parameter append = true to append context to the end

*/

out = new FileOutputStream("b.txt",true);

out.write('腾');

/*

* public void write(int b); 可以是一个char但是,如果在ASCII之外的字符,就只能写一byte结构很坑,不可预期

* public void write(byte[] buf);

* public void write(byte[] buf, int start, int length);

*/

} catch (FileNotFoundException e1) {

// TODO Auto-generated catch block

e1.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally{

if(out != null){

try {

out.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

2.字符流

使用字节流是不可以处理中文的,这样我们就必须使用字符流。字符流的基类是Reader/Writer

Reader BufferedReader

           InputStreamReader    FileReader

    Writer BufferedWriter

           OutputStreamWriter       FileWriter

           PrintWriter

这几个是常见的使用的。

2.1字符数据流输入:

Reader reader= null;

try {

reader = new FileReader(ClassLoader.getSystemResource("a.txt").getPath());

char[] buf  = new char[10];

int count = 0;

while((count = reader.read(buf,0,10)) != -1){

System.out.print(new String(buf,0,count));

}

/*

* use public int read() function return 0x0000~0xffff int value

*/

/*int a;

while((a=reader.read()) != -1){

System.out.println((char)a);

}

*/

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally{

if(reader != null){

try {

reader.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

2.2字符数据流输出:

Writer out = null;

try {

// FileWriter(String filename, boolean append = false);

//FileWriter(File file, boolean append = false);

out = new FileWriter("a.txt",true);

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

char buf[] = {'杨','腾','飞','a','b','c'};

if(out != null){

try {

System.out.println(new String(buf,0,buf.length));

out.write(buf, 0, buf.length);

out.flush();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally{

if(out != null){

try {

out.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

}

3.使用缓冲数据流,提高IO的效率,减少IO的次数

2中的操作数据流的方法特别低效,不适合远程操作或者是大型项目,我们使用缓冲数据流提高IO的性能。

3.1缓冲字节流:

InputStream   FileInputStream

                  FilterInputStream  BufferedInputStream

    OutputStream  FileOutputStream

                  FilterOutputStream BufferedOutputStream  

将FileInputStream/FileOutputStream转换成

BufferedInputStream/BufferedOutputStream

BufferedInputStream bis = null;

try {

bis = new BufferedInputStream(new FileInputStream("a.txt"));

byte [] buf = new byte[10];

int count = -1;

while( (count = bis.read(buf, 0, 10)) != -1){

System.out.print(new String(buf,0,count));

}

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally{

if(bis != null){

try {

bis.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

BufferedOutputStream bos = null;

try {

bos = new BufferedOutputStream(new FileOutputStream("b.txt",true));

byte[] buf = null;

String a = "杨腾飞a";

buf = a.getBytes();

bos.write(buf,0,buf.length);

bos.flush();

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}finally{

if(bos != null){

try {

bos.flush();

bos.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

3.2缓冲字符流:

BufferedReader/BufferedWriter

BufferedReader breader = new BufferedReader(new FileReader(“filename”))

Example:

BufferedReader breader = null;

try {

breader = new BufferedReader(new FileReader("a.txt"));

char[] buf = new char[10];

int count = -1;

while( (count = breader.read(buf, 0, 10))  != -1){

System.out.print(new String(buf,0,count));

}

//每一次获取一行数据,当遇到行结束的时候,终止,返回的是一个字符串,但是不包含换行符。

/*

String a ;

while((a=breader.readLine()) != null){

System.out.println(a);

}

*/

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

缓冲输出流的话,详细你也会了吧,就这样了

在Java 中的输入输出流是十分重要的一个知识点,后面的网络编程也是需要用到这些输入输出流。

追梦的飞飞

于广州中山大学 20131005

HomePage: http://yangtengfei.duapp.com

Java复习7.输入输出流的更多相关文章

  1. 第27章 java I/O输入输出流

    java I/O输入输出流 1.编码问题 import java.io.UnsupportedEncodingException; /** * java涉及的编码 */ public class En ...

  2. JAVA Io 缓冲输入输出流

    java中提供带缓冲的输入输出流.在打开文件进行写入或读取操作时,都会加上缓冲,提高了IO读写性能. 1. BufferedInputStream 缓冲输入流 2. BufferedOutputStr ...

  3. Java I/O输入输出流详解

    一.文件的编码               开发时一定要注意项目默认的编码!!!!!!!!               文件操作的时候一定要记得关闭!!!!!!!!        ASCII:美国标准 ...

  4. Java IO学习--输入输出流

    一.Java IO的定义 I/O:输入输出系统,由输入输出控制系统和外围设备两部分组成. Java中I/O操作主要是指使用Java进行输入,输出操作. Java所有的I/O机制都是基于数据流进行输入输 ...

  5. java实验8-Java输入输出流

    1 读写文件 [实验目的] (1)掌握文本文件的读写方法. (2)掌握随机文件的读写方法. (3)掌握InputStream.OutputStream抽象类的基本使用. (4)掌握FileInputS ...

  6. Java工具类-输入输出流

    输入输出流 1.概念 输入输出流:文件复制,上传 输出流: System.out.println() 写操作,程序将字符流写入到"目的地",比如打印机和文件等 输入流 :Scann ...

  7. java学习笔记-输入输出流

    ================File类 =====================InputStream ==================OutputStream ============== ...

  8. Java中的输入输出流

    FileInputStream和FileOutputStream 创建含磁盘文件的输入 输出流对象. FileInputStream继承自InputStream,用于读取本地文件中的字节数据,由于所有 ...

  9. 《三》Java IO 字节输入输出流

    那么这篇博客我们讲的是字节输入输出流:InputStream.OutputSteam(下图红色长方形框内),红色椭圆框内是其典型实现(FileInputSteam.FileOutStream)     ...

随机推荐

  1. Shiro安全框架入门篇

    一.Shiro框架介绍 Apache Shiro是Java的一个安全框架,旨在简化身份验证和授权.Shiro在JavaSE和JavaEE项目中都可以使用.它主要用来处理身份认证,授权,企业会话管理和加 ...

  2. 关于jQuery获得表单radio类型输入框的选中值

    var item=$("input[name='w1']checked").val(); 下面这句,问题解决(加上[type='radio']:): var item=$(&quo ...

  3. 使用IDEA 创建Servlet 的时候,找不到javax.servlet

    使用IDEA 开发工具,创建Servlet 文件的时候,出现了下面的这种错误, 解决步骤如下: 第一步:点击 File 第二步:找到Project Structure,点击,然后按照下图顺序操作,添加 ...

  4. Druid学习之路 (二)Druid架构

    作者:Syn良子 出处:https://www.cnblogs.com/cssdongl/p/9608812.html 转载请注明出处 Druid架构 Druid原本就设计为一个容易操作的面向云的多进 ...

  5. linux性能分析命令1:top命令

    转载:http://www.cnblogs.com/peida/archive/2012/12/24/2831353.html top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的 ...

  6. Wex5各组件介绍

    1.http://doc.wex5.com/comp-base/ 2.select 组件 http://doc.wex5.com/comps-select/ 3.页面交互以及传递参数  http:// ...

  7. C++中去掉string字符串中的\r\n等

    string imagedata;imagedata = “dudau\r\ndadafca\r\n” CString Image; Image = imagedata.c_str(); Image. ...

  8. Promise原理剖析

    传统的异步回调编程最大的缺陷是:回调地狱,由于业务逻辑非常复杂,代码串行请求好几层:并行请求以前也要通过引用step.async库实现.现在ES6推出了Promise,通过Promise的链式调用可以 ...

  9. bat(续五)-获取批处理文件所在路径

    获取批处理文件所在路径        在开发时,经常需要使用批处理运行一些程序,java程序 犹其是这样,往往需要运行时根路径.Hardcode一个路径总是令自己觉得不自在,例如一个java程序从一台 ...

  10. [BZOJ4003]城池攻占

    Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池. 这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖, ...