文件操作之读取文件

转载 2012年03月22日 15:35:30

转载自:http://jc-dreaming.iteye.com/blog/639817

虽然前面介绍了流的概念,但是这个概念对于初学者来说,还是比较抽象的,下面以实际的读取文件为例子,介绍流的概念,以及输入流的基本使用。 
  按照前面介绍的知识,将文件中的数据读入程序,是将程序外部的数据传入程序中,应该使用输入流——InputStream或Reader.而由于读取的是特定的数据源——文件,则可以使用输入对应的子类FileInputStream或FileReader实现。 
  在实际书写代码时,需要首先熟悉读取文件在程序中实现的过程。在Java语言的IO编程中,读取文件是分两个步骤:1、将文件中的数据转换为流,2、读取流内部的数据。其中第一个步骤由系统完成,只需要创建对应的流对象即可,对象创建完成以后步骤1就完成了,第二个步骤使用输入流对象中的read方法即可实现了。 
  使用输入流进行编程时,代码一般分为3个部分:1、创建流对象,2、读取流对象内部的数据,3、关闭流对象。下面以读取文件的代码示例: 
  import java.io.*; 
  /** 
  * 使用FileInputStream读取文件 
  */ 
  public class ReadFile1 { 
  public static void main(String args) { 
  //声明流对象 
  FileInputStream fis = null;try{ 
  //创建流对象 
  fis = new FileInputStream("e:““a.txt"); 
  //读取数据,并将读取到的数据存储到数组中 
  byte data = new byte[1024]; //数据存储的数组 
  int i = 0; //当前下标 
  //读取流中的第一个字节数据 
  int n = fis.read(); 
  //依次读取后续的数据 
  while(n != -1){ //未到达流的末尾 
  //将有效数据存储到数组中 
  data[i] = (byte)n; 
  //下标增加 
  i++; 
  //读取下一个字节的数据 
  n = fis.read(); 
  } 
  //解析数据 
  String s = new String(data,0,i); 
  //输出字符串 
  System.out.println(s); 
  }catch(Exception e){ 
  e.printStackTrace(); 
  }finally{ 
  try{ 
  //关闭流,释放资源 
  fis.close(); 
  }catch(Exception e){} 
  } 
  } 
  }||| 
  在该示例代码中,首先创建一个FileInputStream类型的对象fis: 
fis = new FileInputStream("e:““a.txt"); 
  这样建立了一个连接到数据源e:“a.txt的流,并将该数据源中的数据转换为流对象fis,以后程序读取数据源中的数据,只需要从流对象fis中读取即可。 
  读取流fis中的数据,需要使用read方法,该方法是从InputStream类中继承过来的方法,该方法的作用是每次读取流中的一个字节,如果需要读取流中的所有数据,需要使用循环读取,当到达流的末尾时,read方法的返回值是-1. 
  在该示例中,首先读取流中的第一个字节: 
  int n = fis.read(); 
  并将读取的值赋值给int值n,如果流fis为空,则n的值是-1,否则n中的最后一个字节包含的时流fis中的第一个字节,该字节被读取以后,将被从流fis中删除。 
  然后循环读取流中的其它数据,如果读取到的数据不是-1,则将已经读取到的数据n强制转换为byte,即取n中的有效数据——最后一个字节,并存储到数组 data中,然后调用流对象fis中的read方法继续读取流中的下一个字节的数据。一直这样循环下去,直到读取到的数据是-1,也就是读取到流的末尾则循环结束。 
  这里的数组长度是1024,所以要求流中的数据长度不能超过1024,所以该示例代码在这里具有一定的局限性。如果流的数据个数比较多,则可以将1024扩大到合适的个数即可。 
  经过上面的循环以后,就可以将流中的数据依次存储到data数组中,存储到data数组中有效数据的个数是i个,即循环次数。 
  其实截至到这里,IO操作中的读取数据已经完成,然后再按照数据源中的数据格式,这里是文件的格式,解析读取出的byte数组即可。 
  该示例代码中的解析,只是将从流对象中读取到的有效的数据,也就是data数组中的前n个数据,转换为字符串,然后进行输出。 
  在该示例代码中,只是在catch语句中输出异常的信息,便于代码的调试,在实际的程序中,需要根据情况进行一定的逻辑处理,例如给出提示信息等。 
  最后在finally语句块中,关闭流对象fis,释放流对象占用的资源,关闭数据源,实现流操作的结束工作。 
  上面详细介绍了读取文件的过程,其实在实际读取流数据时,还可以使用其它的read方法,下面的示例代码是使用另外一个read方法实现读取的代码: 
  import java.io.FileInputStream; 
  /** 
  * 使用FileInputStream读取文件 
  */ 
  public class ReadFile2 { 
  public static void main(String args) { 
  //声明流对象 
  FileInputStream fis = null;try{ 
  //创建流对象 
  fis = new FileInputStream("e:““a.txt"); 
  //读取数据,并将读取到的数据存储到数组中 
  byte data = new byte[1024]; //数据存储的数组 
  int i = fis.read(data); 
  //解析数据 
  String s = new String(data,0,i); 
  //输出字符串 
  System.out.println(s); 
  }catch(Exception e){ 
  e.printStackTrace(); 
  }finally{ 
  try{ 
  //关闭流,释放资源 
  fis.close(); 
  }catch(Exception e){} 
  } 
  } 
  } 
  该示例代码中,只使用一行代码: 
  int i = fis.read(data); 
  就实现了将流对象fis中的数据读取到字节数组data中。该行代码的作用是将fis流中的数据读取出来,并依次存储到数组data中,返回值为实际读取的有效数据的个数。 
  使用该中方式在进行读取时,可以简化读取的代码。 
  当然,在读取文件时,也可以使用Reader类的子类FileReader进行实现,在编写代码时,只需要将上面示例代码中的byte数组替换成char数组即可。 
  使用FileReader读取文件时,是按照char为单位进行读取的,所以更适合于文件的读取,而对于二进制文件或自定义格式的文件来说,还是使用FileInputStream进行读取,方便对于读取到的数据进行解析和操作。 
  读取其它数据源的操作和读取文件类似,最大的区别在于建立流对象时选择的类不同,而流对象一旦建立,则基本的读取方法是一样,如果只使用最基本的read 方法进行读取,则使用基本上是一致的。这也是IO类设计的初衷,使得对于流对象的操作保持一致,简化IO类使用的难度。 

相关文章推荐

delphi 读取文件操作

  • 2013年10月18日 14:09
  • 363KB
  • 下载

Android文件操作(写入和读取)

  • 2015年11月27日 12:33
  • 6.29MB
  • 下载

jsp,java文件操作(新建,删除,读取,写入)(转载)

在javajsp中有很多的地方要用到对文件的操作,文件操作也很简单,下面就列举一些文件操作的常用方法  jsp文件操作常用方法: mkdir() 方法用于对文件夹的创建    del...

idom读取文件操作

  • 2012年08月13日 21:46
  • 65KB
  • 下载

c#读取ini文件操作类

using System; using System.Runtime.InteropServices; using System.Collections.Generic; namespace Co...

Scala文件操作----(读取和写入字符)

Scala文件操作----(读取和写入字符)

IOS Plist文件操作之写入/读取/删除

摘要: 1.保存在user Document文件夹下,以读取文件,写入文件方式 2.在工程里手动创建一个.plist文件,把固定的内容写入,这个需要人工手动写入(工程里只可读取,不可以写入) 3....

java io文件操作(多种读取方式-字节,字符,行,随机)

一、多种方式读文件内容。 1、按字节读取文件内容 2、按字符读取文件内容 3、按行读取文件内容 4、随机读取文件内容 import java.io.BufferedReader; ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:文件操作之读取文件
举报原因:
原因补充:

(最多只允许输入30个字)