欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java基础之IO技术(一)

程序员文章站 2022-04-28 13:29:44
恢复内容开始 Java基础中的IO技术可谓是非常重要,俗话说的好,万丈高楼起于垒土之间。所以学习Java一定要把基础学好,今天我们来学习IO技术的基础。 IO无非就是输入与输出,而其中处理的数据无非是字符与字节。字符最简单的定义就是这个数据是否是纯文本组成,除此之外所有的都是字节。Java给我们提供 ......

---恢复内容开始---

  java基础中的io技术可谓是非常重要,俗话说的好,万丈高楼起于垒土之间。所以学习java一定要把基础学好,今天我们来学习io技术的基础。

  io无非就是输入与输出,而其中处理的数据无非是字符与字节。字符最简单的定义就是这个数据是否是纯文本组成,除此之外所有的都是字节。java给我们提供了字符和字节的处理,其中字符的处理有writer和reader两个抽象父类(分别对应的是写和读),字节的处理有outputstream和inputstream两个抽象类(分别对应的是写和读)。今天我们就看看字符的处理。

  字符的处理

  1.字符的读(filereader)

  首先请看一段代码:

 1 import java.io.*;
 2 
 3 public class filereader1 {
 4     public static void main(string[] args){
 5         filereader fr = null;
 6         try{
 7             fr = new filereader("1.txt");
 8             int ch = 0;
 9             //read():字符读取,如果已经达到流的结尾,则为-1
10             //这个可以作为读取文件结束的条件
11             while((ch = fr.read()) != -1){
12                 //进行强制转换
13                 system.out.print((char)ch);
14             }
15             sop("读取结束");
16 
17         }catch(filenotfoundexception e){
18             sop(e.tostring());
19         }catch(ioexception e){
20             sop(e.tostring());
21         }finally{
22             try {
23                 if(fr != null) {
24                     fr.close();
25                 }
26             }catch(ioexception e){
27                 sop(e.tostring());
28             }
29         }
30     }
31     public static void sop(object obj){
32         system.out.println(obj);
33     }
34 }

 

  这是文件读取的第一种方法,这种方法是将文件中的数据一个一个的读出来,这样操作比较耗资源,因此有了第二种读取方法,请看下面这段代码。

 1 import java.io.*;
 2 
 3 public class filereader2 {
 4     public static void main(string[] args){
 5         filereader fr = null;
 6         try{
 7             fr = new filereader("1.txt");
 8             //read(char[] cbuf):将字符读取到数组中
 9             //这个数组大小1024整数倍
10             char[] buff = new char[1024];
11             int num = 0;
12             while((num = fr.read(buff)) != -1){
13                 sop(new string(buff, 0, num));
14             }
15 
16         }catch(filenotfoundexception e){
17             sop(e.tostring());
18         }catch(ioexception e){
19             sop(e.tostring());
20         }finally{
21             try{
22                 if(fr != null) {
23                     fr.close();
24                 }
25             }catch(ioexception e){
26                 sop(e.tostring());
27             }
28         }
29 
30     }
31     public static void sop(object obj){
32         system.out.println(obj);
33     }
34 }

 

  这种方法是利用一个数组(这个数组大小一般定义为1024的整数倍),将文件中的数据传入到一个数组中,然后将数组中的数据一次性的处理。显而易见这种方法更好。

  文件打开是需要关闭的,通过close方法。

 

  2.字符的写(filewriter)

  首先请看下面一段代码

 1 import java.io.*;
 2 
 3 public class filewriterdemo {
 4     public static void main(string[] args){
 5         filewriter();
 6 
 7     }
 8     public static void filewriter(){
 9         filewriter fw = null;
10         try {
11             fw = new filewriter("1.txt");
12 
13             fw.write("asdsadasdafd");
14             fw.flush();
15 
16             fw.append("\n"+123);
17             fw.flush();
18 
19         }catch(ioexception e){
20             sop(e.tostring());
21         }finally{
22             try{
23                 if(fw != null) {
24                     fw.close();
25                 }
26             }catch(ioexception e){
27                 sop(e.tostring());
28             }
29         }
30     }
31     public static void sop(object obj){
32         system.out.println(obj);
33     }
34 }

 

  首先对象的创立,有多个构造函数。这里我介绍两种,filewriter(string filename)和filewriter(string filename, boolean append)。在第二个构造函数中有一个布尔型参数,为false就和第一个构造函数一样,每次向目的地中写入数据时都会覆盖原来的数据,若不想覆盖原来的数据,可以使用append方法;为true时,就不会覆盖原来的数据,而是在原数据后面追加数据。

  文件的写入是通过一个缓冲区(为了解决cpu和硬盘速度并不匹配的问题),因此在写入一段数据后,要通过flush方法刷新缓冲区,将数据送到目的地中(文件)。最后通过close方法关闭资源,在关闭之前也会刷新缓冲区。每次向目的地写入数据时,都会检测是否有目的文件,若没有则创建一个。

  为提高数据的读写效率,java中提供了缓冲技术,对原来的filewriter与filereader进行修饰,其中涉及到了修饰设计模式,这里就不具体讲解。下面就对缓冲技术进行讲解。

 

  3.修饰后的写(bufferedwriter)

  我们还是来看看具体代码

 1 import java.io.*;
 2 
 3 public class bufferedwriterdemo {
 4     public static void main(string[] args){
 5         //创建一个字符写入流对象
 6         filewriter fw = null;
 7         bufferedwriter bw = null;
 8         try{
 9             fw = new filewriter("2.txt", true);
10             //为提高字符写入的流效率,加入了缓冲技术。
11             //只要将需要提高效率的流对象作为参数传递给缓冲区的构造函数
12             bw = new bufferedwriter(fw);
13             for(int i=0; i<5; i++) {
14                 bw.write("sdadadas"+i);
15                 bw.newline();
16             }
17             //记住,只要用到缓冲区就要刷新
18             bw.flush();
19 
20         }catch(ioexception e){
21             sop(e.tostring());
22 
23         }finally {
24             try{
25                 //其实关闭缓冲区,就是在关闭与缓冲区关联的流对象
26                 bw.close();
27             }catch(ioexception e){
28                 sop(e.tostring());
29             }
30         }
31 
32 
33     }
34     private static void sop(object obj){
35         system.out.println(obj);
36     }
37 }

 

  这一段知识尽在代码与注释中。其中有一个newline方法,让我们看看1.8api中解释(写一行行分隔符。 行分隔符字符串由系统属性line.separator定义,并不一定是单个换行符('\ n')字符)。在不同系统中,换行符都不同。而使用了这个方法后,同样的代码不会在不同的系统中出现乱码的问题。

  最后的close方法,有一个疑问(到底是使用流对象的close方法还是使用缓冲技术的close方法呢),首先我们回到一开始,缓冲技术是用来修饰流操作的,必然他们操作的是流。因此使用其中任何一个close方法都会关闭这个流资源。

 

  4.修饰后的读(bufferedreader)

  请看下一段代码

 

 1 import java.io.*;
 2 
 3 public class bufferedreaderdemo {
 4     public static void main(string[] args){
 5         filereader fr = null;
 6         bufferedreader br = null;
 7         try{
 8             //创建一个读取流对象并与文件关联
 9             fr = new filereader("2.txt");
10             //为了提高效率,加入了缓冲区技术。将字符读取流对象作为参数传入到缓冲对象的构造函数
11             br = new bufferedreader(fr);
12 
13             string line = null;
14             while((line = br.readline()) != null){
15                 sop(line);
16             }
17 
18         }catch(filenotfoundexception e){
19             sop(e.tostring());
20         }catch(ioexception e){
21             sop(e.tostring());
22         }finally {
23             try{
24                 if(br != null){
25                     br.close();
26                 }
27             }catch(ioexception e){
28                 sop(e.tostring());
29             }
30         }
31     }
32 
33     private static void sop(object obj){
34         system.out.println(obj);
35     }
36 }

  

  这段知识的原理和上一段的知识类似,就不做具体的解释了。就说说其中的readline方法,我们来看看api文档,public string readline(),(读一行文字。 一行被视为由换行符('\ n'),回车符('\ r')中的任何一个或随后的换行符终止),也就是说把文件中的一行数据读取出来。

  我们总结一下字符的体系

 1 /**
 2  * 读:
 3  *      reader
 4  *          |--filereader(两种读的方法,资源的关闭)
 5  *          |--bufferedreader(修饰设计模式,高效的处理方式,readline方法,close方法关闭资源)
 6  *
 7  * 写:
 8  *      writer
 9  *          |--filewriter(两种构造方法,write方法与append方法,)
10  *          |--bufferedwriter(修饰设计模式,高效的处理方式,newline方法,close方法关闭资源)
11  *
12  *
13  * */

 

 

 

  今天只讲解了字符的操作,关于字节的操作和其他io的基础知识,在后面会相应的推出。

 

 

 

 

---恢复内容结束---