Java中的IO流是用来处理设备与设备之前的数据传输,在java中以流的形式传输。流分为两类:字节流和字符流。
字节流:InputStream,OutPutSteam.(计算机内的数据都是以字节存储的,字节流可以操作任意数据)
字符流:Reader,Writer.(字符流只能操作字符,但是在实际应用中字符流比较方便)
从操作来看又可以分为:输入流和输出流。
在进行IO流操作的时候分为以下几步:1.导入IO流的包,2.进行IO流的异常处理,3.关闭IO流释放资源。
字节流
————————————————————————————————————————————————————————————————————————————————————————————————————————————
FileInputStream:
FileInputStream fis =new FileInputStram("xxx.text");
int b;
//读取标准写法
while((b=fis.read)!=-1){
System.out.println(b);
}
fis.close();
FileOutputSteam:
FileOutputStream fos=new FileOutputStream("xxx.text",true);//FileOutputStream默认每次回重新生成一个“xxx.text”,如果想要追加,应该加一个true
fos.write();
fos.close();
Java中的缓冲区:
在读写数据的时候,一次读写一个数组明显比一个一个字节的读取速度要快的多,所以考虑到这种设计思想,引入了缓冲区。实际上就是对流进行包装。(装饰设计思想)
BufferInputStream和BufferOutputStream:
BufferedInputStream bis=new BufferedInputStream(new FileInputStrean("xxx.txt"));
BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream("yyy.txt")
byte[]by=new byte[1024]
int len
while((len=bis.read(by))!=-1){ bos.write(arr,0,len);
}
bis.close();//只需要关闭BufferInputStream
bos.close();
JDK 1.7以下流的异常处理:
需要注意的是在做IO流的异常处理的时候,不能进行try catch.因为IO流是用来操作底层的数据,如果进行了try catch相当于把IO问题隐藏了,无法向上暴露,真确的做法是将IO异常抛出。
try{BufferedInputStream bis=new BufferedInputStream(new FileInputStrean("xxx.txt"));
BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream("yyy.txt")
byte[]by=new byte[1024]
int len
while((len=bis.read(by))!=-1){ bos.write(arr,0,len);
}
}finally{
if(bis!=null){
bis.close();//只需要关闭Buffer
}
if(bos!=null){
bos.close();
}
}
JDK 1.7以上流的异常处理:
不需要手动关闭,程序自动关闭。
try(
BufferInputStream bis=new BufferInputStream(new FileInputStrean("xxx.txt"));
BufferOutputStream bos=new BufferOutputStream(new FileOutputStream("yyy.txt")
)
{
byte[]by=new byte[1024]
int len
while((len=bis.read(by))!=-1){ bos.write(arr,0,len);
}
}
字符流
———————————————————————————————————————————————————————————————————————————————————— FileReader:
FileReader fr=new FileReader("xxx.txt")
int c;
while((c=fr.read())!=-1){ //read()方法按照字符大小读取
System.out.print((char)c);
}
c.close();
FileWriter:
FileWriter fw=new FileWriter("xxx.txt")
fw.wrire("你好"); write()方法自动将字符装字节写入
fw.close();
字符流的拷贝:
FileReader fr=new FileReader("xxx.txt");
FileWriter fw=new FileWriter("zzz,txt");
int c;
while((c=fr.read())!=-1){ fw.writer(c);
}
fr.close();
fw.close();
字符流和字节流都可以拷贝文件,但是不推荐使用字符就拷贝文件,因为读取的时候要将字节流转换为字符流,写入的时候要将字符流转换位字节流,太过耗时!
当程序需要读写一段文本时,推荐使用字符流,因为它是按码读取,不会出现半个中文的情况,更加准确!写出时也不用转换为字节流。需要注意的是,使用字符流拷贝时,只能拷纯文本。在读的时候将字符转换为字节的时候可能找不到对应的字节,出现字节丢失。
自定义字节数组拷贝:
FileReader fr=new FileReader("xxx.txt");
FileWriter fw=new FileWriter("zzz.txt");
char[]by=new char[1024];
int len;
while((len=fr.read(by))!=-1){//将文件上的数据转到字符数组中 fw.write(by,0,len);//字符数组中的字符转到文件中
}
fr.close();
fw.close();
带缓冲的字节数组拷贝:
BufferedReader br=new BufferReader(new FileReader ("xxx.txt"));
BufferedWriter bw=new BufferWriter(new BufferWriter("zzz.txt"));
int c
while((c=br.read())!=-1){
bw.writer(c);
}
br.close();
bw.close();
BufferReader和BufferWriter:
BufferedReader br=new BufferReader(new FileReader("xxx.txt"));
BufferedWriter bw=new BufferWriter(new FileWriter("zzz.txt"))
String line;
while((line=br.readLine())!=null){读取一行字符
bw.write(line);
bw.nextLine();//换行 }
br.close();
bw.close();
简单应用实现文本反转:
BufferedReader br=new BufferReader(new FileReader("xxx.txt")); String line;
ArrayList<String>list=new ArrayList<>();
while((line=br.readLine())!=null){ list.add(line); }
br.close();
BufferedWriter br=new BufferReader(new FileWriter("zzz.txt"));
for(int i=line.size();i>=0;i--){ bw.write(list.get(i)); bw.nextLine(); }
bw.close();
IO流中的装饰设计模式————————————————————————————————————————————————————————————————————————————————————————
设计模式的来源:设计模式最早来源于建筑行业,为了让对象更加容进行推广,进行程序化操作。
装饰设计模式的实质就是对对象进行包装,让他更加具有操作性,在IO流中,Buffer就是一种装饰。装饰设计模式的好处是:耦合性不强,装饰类与被装饰类的变化无关。