# JAVA之旅(二十五)——文件复制,字符流的缓冲区,BufferedWriter,BufferedReader,通过缓冲区复制文件,readLine工作原理,自定义readLine
* * *
> 我们继续IO上个篇幅讲
## 一.文本复制
> 读写都说了,我们来看下其他的操作,我们首先来看复制
* 复制原理:其实就是将C盘下的文件数据存储到D盘的一个文件中
> 实现的步骤:
> 1.在D盘创建一个文件,用于存储文件中的数据
> 2.定义读取流和文件关联
> 3.通过不断的读写完成数据的存储
> 关闭资源
~~~
package com.lgl.hellojava;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class HelloJJAVA {
public static void main(String[] args) {
copy_1();
copy_2();
}
// 从c盘读一个字符,就往D盘写一个字符
public static void copy_1() {
try {
// 创建目的地
FileWriter fw = new FileWriter("copy_1.txt");
// 与已有文件关联
FileReader fr = new FileReader("copy_1.txt");
int ch = 0;
while ((ch = fr.read()) != -1) {
// 读一个 写一个
fw.write(ch);
}
fw.close();
fr.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static void copy_2() {
FileWriter fw = null;
FileReader fr = null;
try {
fw = new FileWriter("copy_2.txt");
fr = new FileReader("copy_2.txt");
char[] buf = new char[1024];
int len = 0;
while ((len = fr.read(buf)) != -1) {
fw.write(buf, 0, len);
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (fr != null) {
try {
fr.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (fw != null) {
try {
fw.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
~~~
> 这里做了两种方式的拷贝方式,其实都是整理好思路,读和写的一个过程罢了!
## 二.字符流的缓冲区
> 字符流的缓冲区,提高了对数据的读写效率,他有两个子类
* BufferedWriter
* BufferedReader
> 缓冲区要结合柳才可以使用
> 在流的基础上对流的功能进行了增强
### 1.BufferedWriter
![这里写图片描述](http://img.blog.csdn.net/20160702170355221)
> 缓冲区的出现是提高流的效率而出现的,所以在创建缓冲区之前,必须先有流对象,我们看例子
~~~
package com.lgl.hellojava;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
public class HelloJJAVA {
public static void main(String[] args) {
try {
// 创建一个字符写入流对象
FileWriter fw = new FileWriter("buffer.txt");
// 为了提高写入流的效率加入了缓冲技术
BufferedWriter bufw = new BufferedWriter(fw);
//写入数据
bufw.write("hello");
//换行
bufw.newLine();
//只要用到了缓冲区,就需要刷新
bufw.flush();
//缓冲区关闭的就是关联的流
bufw.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
~~~
> 使用都是比较基础的,大家也是可以看到
### 2.BufferedReader
> 高效读取
![这里写图片描述](http://img.blog.csdn.net/20160702170544941)
> 我们直接看代码
~~~
package com.lgl.hellojava;
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
public class HelloJJAVA {
public static void main(String[] args) {
try {
// 创建一个读取流对象和文件相关联
FileReader fr = new FileReader("buffer.txt");
// 为了提高效率,加入缓冲技术
BufferedReader bfr = new BufferedReader(fr);
String line = null;
while((line = bfr.readLine()) != null){
System.out.println(line);
}
bfr.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
~~~
> 这样就可以全部出来了
## 三.通过缓冲区复制文件
> OK,我们还是复制文件这个问题,现在我们有缓冲区,我们要怎么样复制文件?
~~~
package com.lgl.hellojava;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class HelloJJAVA {
public static void main(String[] args) {
/**
* 缓冲区文件复制
*/
BufferedReader bufr = null;
BufferedWriter bufw = null;
try {
bufr = new BufferedReader(new FileReader("buffer.txt"));
bufw = new BufferedWriter(new FileWriter("buffercopy.txt"));
String line = null;
while((line = bufr.readLine()) != null){
bufw.write(line);
}
//关闭流
bufr.close();
bufw.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
~~~
> 这样,就可以复制文件了
## 四.readLine工作原理
> 我们注意到我们要使用这个方法readline,无论是读一行还是读多个字符,其实都是在硬盘上一个一个读取,所以最终使用的还是read方法一个读一个的方法
* 其实他内存中有一个数组,你读完之后并没有立马读,而是临时存储起来,这就是缓冲区,
![这里写图片描述](http://img.blog.csdn.net/20160702173638937)
> 当读到换行,才去返回一行数据,就这样一行一行的读取,这就是他的工作原理
## 五.自定义readLine
> 我们了解了readLine的工作原理,那我们就可以尝试去更改他了,自定义一个怎么样?我们尝试一下
~~~
package com.lgl.hellojava;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
public class HelloJJAVA {
public static void main(String[] args) {
/**
* 自定义readLine
*/
FileReader fr;
try {
fr = new FileReader("buffer.txt");
MyBufferReader my = new MyBufferReader(fr);
String line = null;
while ((line = my.myReadLine()) != null) {
System.out.println(line);
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class MyBufferReader {
private FileReader fr;
public MyBufferReader(FileReader fr) {
this.fr = fr;
}
// 一次读取一行的方法
public String myReadLine() throws IOException {
// 定义临时容器
StringBuilder sb = new StringBuilder();
int ch = 0;
while ((ch = fr.read()) != -1) {
if (ch == '\r') {
continue;
} else if (ch == '\n') {
return sb.toString();
} else {
sb.append((char) ch);
}
}
if(sb.length() != 0){
return sb.toString();
}
return null;
}
public void close() throws IOException {
fr.close();
}
}
~~~
> 仔细看实现思路,静静的看,没错,我们也是可以实现的,好的,我们本篇到这里也OK,算是结束了,我们下一篇继续会将IO的,毕竟这是一个大知识点!
## 有兴趣可以加群:555974449
版权声明:本文为博主原创文章,博客地址:http://blog.csdn.net/qq_26787115,未经博主允许不得转载。
- 0-发现
- AndroidInterview-Q-A
- Android能让你少走弯路的干货整理
- LearningNotes
- temp
- temp11
- 部分地址
- 0-待办任务
- 待补充列表
- 0-未分类
- AndroidView事件分发与滑动冲突处理
- Spannable
- 事件分发机制详解
- 1-Java
- 1-Java-01基础
- 未归档
- 你应该知道的JDK知识
- 集合框架
- 1-Java-04合集
- Java之旅0
- Java之旅
- JAVA之旅01
- JAVA之旅02
- JAVA之旅03
- JAVA之旅04
- JAVA之旅05
- JAVA之旅06
- JAVA之旅07
- JAVA之旅08
- JAVA之旅09
- java之旅1
- JAVA之旅10
- JAVA之旅11
- JAVA之旅12
- JAVA之旅13
- JAVA之旅14
- JAVA之旅15
- JAVA之旅16
- JAVA之旅17
- JAVA之旅18
- JAVA之旅19
- java之旅2
- JAVA之旅20
- JAVA之旅21
- JAVA之旅22
- JAVA之旅23
- JAVA之旅24
- JAVA之旅25
- JAVA之旅26
- JAVA之旅27
- JAVA之旅28
- JAVA之旅29
- java之旅3
- JAVA之旅30
- JAVA之旅31
- JAVA之旅32
- JAVA之旅33
- JAVA之旅34
- JAVA之旅35
- 1-Java-05辨析
- HashMapArrayMap
- Java8新特性
- Java8接口默认方法
- 图解HashMap(1)
- 图解HashMap(2)
- 2-Android
- 2-Android-1-基础
- View绘制流程
- 事件分发
- AndroidView的事件分发机制和滑动冲突解决
- 自定义View基础
- 1-安卓自定义View基础-坐标系
- 2-安卓自定义View基础-角度弧度
- 3-安卓自定义View基础-颜色
- 自定义View进阶
- 1-安卓自定义View进阶-分类和流程
- 10-安卓自定义View进阶-Matrix详解
- 11-安卓自定义View进阶-MatrixCamera
- 12-安卓自定义View进阶-事件分发机制原理
- 13-安卓自定义View进阶-事件分发机制详解
- 14-安卓自定义View进阶-MotionEvent详解
- 15-安卓自定义View进阶-特殊形状控件事件处理方案
- 16-安卓自定义View进阶-多点触控详解
- 17-安卓自定义View进阶-手势检测GestureDetector
- 2-安卓自定义View进阶-绘制基本图形
- 3-安卓自定义View进阶-画布操作
- 4-安卓自定义View进阶-图片文字
- 5-安卓自定义View进阶-Path基本操作
- 6-安卓自定义View进阶-贝塞尔曲线
- 7-安卓自定义View进阶-Path完结篇伪
- 8-安卓自定义View进阶-Path玩出花样PathMeasure
- 9-安卓自定义View进阶-Matrix原理
- 通用类介绍
- Application
- 2-Android-2-使用
- 2-Android-02控件
- ViewGroup
- ConstraintLayout
- CoordinatorLayout
- 2-Android-03三方使用
- Dagger2
- Dagger2图文完全教程
- Dagger2最清晰的使用教程
- Dagger2让你爱不释手-终结篇
- Dagger2让你爱不释手-重点概念讲解、融合篇
- dagger2让你爱不释手:基础依赖注入框架篇
- 阅读笔记
- Glide
- Google推荐的图片加载库Glide:最新版使用指南(含新特性)
- rxjava
- 这可能是最好的RxJava2.x入门教程完结版
- 这可能是最好的RxJava2.x入门教程(一)
- 这可能是最好的RxJava2.x入门教程(三)
- 这可能是最好的RxJava2.x入门教程(二)
- 这可能是最好的RxJava2.x入门教程(五)
- 这可能是最好的RxJava2.x入门教程(四)
- 2-Android-3-优化
- 优化概况
- 各种优化
- Android端秒开优化
- apk大小优化
- 内存分析
- 混淆
- 2-Android-4-工具
- adb命令
- 一键分析Android的BugReport
- 版本控制
- git
- git章节简述
- 2-Android-5-源码
- HandlerThread 源码分析
- IntentService的使用和源码分析
- 2-Android-9-辨析
- LRU算法
- 什么是Bitmap
- 常见图片压缩方式
- 3-Kotlin
- Kotlin使用笔记1-草稿
- Kotlin使用笔记2
- kotlin特性草稿
- Kotlin草稿-Delegation
- Kotlin草稿-Field
- Kotlin草稿-object
- 4-JavaScript
- 5-Python
- 6-Other
- Git
- Gradle
- Android中ProGuard配置和总结
- gradle使用笔记
- Nexus私服搭建
- 编译提速最佳实践
- 7-设计模式与架构
- 组件化
- 组件化探索(OKR)
- 1-参考列表
- 2-1-组件化概述
- 2-2-gradle配置
- 2-3-代码编写
- 2-4-常见问题
- 2-9-值得一读
- 8-数据结构与算法
- 0临时文件
- 汉诺塔
- 8-数据-1数据结构
- HashMap
- HashMap、Hashtable、HashSet 和 ConcurrentHashMap 的比较
- 迟到一年HashMap解读
- 8-数据-2算法
- 1个就够了
- Java常用排序算法(必须掌握的8大排序算法)
- 常用排序算法总结(性能+代码)
- 必须知道的八大种排序算法(java实现)
- 9-职业
- 阅读
- 书单
- 面试
- 面试-01-java
- Java面试题全集骆昊(上)
- Java面试题全集骆昊(下)
- Java面试题全集骆昊(中)
- 面试-02-android
- 40道Android面试题
- 面试-03-开源源码
- Android图片加载框架最全解析(二),从源码的角度理解Glide的执行流程
- 面试-07-设计模式
- 面试-08-算法
- 面试-09-其他
- SUMMARY
- 版权说明
- temp111