java 输入输出IO流 字节流| 字符流 的缓冲流:BufferedInputStream;BufferedOutputStream;BufferedReader(Reader in);BufferedWriter(Writer out)
什么是缓冲流:
缓冲流的基本原理,是在创建流对象时,会创建一个内置的默认大小的缓冲区数组,通过缓冲区读写,减少系统IO次数,从而提高读写的效率。
图解:
1、字节缓冲流BufferedInputStream;BufferedOutputStream:
- public BufferedInputStream(InputStream in) :创建一个 新的缓冲输入流。
- public BufferedOutputStream(OutputStream out) : 创建一个新的缓冲输出流。
案例对比:
使用缓冲流,拷贝文件每次拷贝1024字节
import java.io.*; /** * @ClassName FileCopyTryCatchBuffer * @projectName: object1 * @author: Zhangmingda * @description: XXX * date: 2021/4/17. */ public class FileCopyTryCatchBuffer { public static void main(String[] args) { String srcPath = "C:\\Users\\ZHANGMINGDA\\Pictures\\康熙北巡.jpg"; String dstpath = "C:\\Users\\ZHANGMINGDA\\Pictures\\康熙北巡bak.jpg"; byte[] tmpbytes = new byte[1024]; int copyLength; long startTime = System.currentTimeMillis(); try(InputStream bfis = new BufferedInputStream(new FileInputStream(srcPath)); OutputStream bfos = new BufferedOutputStream(new FileOutputStream(dstpath))){ while ((copyLength = bfis.read(tmpbytes)) != -1){ bfos.write(tmpbytes,0,copyLength); } }catch(FileNotFoundException e){ e.printStackTrace(); }catch (IOException e){ e.printStackTrace(); } long endTime = System.currentTimeMillis(); System.out.println("拷贝花费ms时间:" + (endTime - startTime)); } }
不使用缓冲流,拷贝文件每次拷贝1024字节
import java.io.*; /** * @ClassName FileCopyBytesExample * @projectName: object1 * @author: Zhangmingda * @description: XXX * date: 2021/4/17. */ public class FileCopyBytesExample { public static void main(String[] args) throws IOException { long startTime = System.currentTimeMillis(); String srcPath = "C:\\Users\\ZHANGMINGDA\\Pictures\\康熙北巡.jpg"; String dstpath = "C:\\Users\\ZHANGMINGDA\\Pictures\\康熙北巡bak.jpg"; InputStream fis = new FileInputStream(srcPath); OutputStream fos = new FileOutputStream(dstpath); byte[] tmpBytes = new byte[1024]; int length ; while ((length = fis.read(tmpBytes)) != -1) { fos.write(tmpBytes,0,length); } long endTime = System.currentTimeMillis(); fis.close(); fos.close(); System.out.println("拷贝耗时ms:" + (endTime -startTime)); } }
2、字符缓冲流BufferedReader(Reader in);BufferedWriter(Writer out) :
构造方法:
- public BufferedReader(Reader in) :创建一个新的缓冲输入流。
- public BufferedWriter(Writer out) : 创建一个新的缓冲输出流。
看它们具备的特有方法:
- BufferedReader: public String readLine() : 读一行文字。读到最后一行返回null。
- BufferedWriter: public void newLine() : 写一行行分隔符,由系统属性定义符号。
练习:打乱的诗词排序
1->独立寒秋,湘江北去,橘子洲头。 2->看万山红遍,层林尽染; 3->漫江碧透,百舸争流。 4->鹰击长空,鱼翔浅底, 5->万类霜天竞自由。
使用treeSet 对诗词语句排序:
import java.io.*; import java.sql.SQLOutput; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.TreeSet; /** * @ClassName TextCopyTryCatchExample * @projectName: object1 * @author: Zhangmingda * @description: XXX * date: 2021/4/18. */ public class TextCopyTryCatchExample { public static void main(String[] args){ String srcpath = "输入输出文件读写/src/test/output/沁园春雪-长沙.txt"; String dstpath = "输入输出文件读写/src/test/output/沁园春雪-长沙-sort.txt"; try (BufferedReader bufferedReader = new BufferedReader(new FileReader(srcpath)); BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter(dstpath))) { String tmpStringLine ; //存放临时的每行文本 Map<Integer,String> tmpMap = new HashMap<>(); //存放诗词语句和顺序序号的对应 TreeSet<Integer> indexSet = new TreeSet(); //对数字排序 while ((tmpStringLine = bufferedReader.readLine()) != null){ String[] tmpLineArr = tmpStringLine.split("->"); int indexKey = Integer.parseInt(tmpLineArr[0]); indexSet.add(indexKey); //TreeSet 集合插入元素按数字大小进行自动排序1,2,3... tmpMap.put(indexKey,tmpLineArr[1]); //Map集合 } //按顺序遍历,写入到新文件 for(Integer index : indexSet){ System.out.println(index); bufferedWriter.write(index + "->" + tmpMap.get(index)); bufferedWriter.newLine(); } }catch (FileNotFoundException e){ e.printStackTrace(); }catch (IOException e ){ e.printStackTrace(); }finally { } } }
排序需求其实可以不用TreeSet也行。
HashMap具体的数据要存放在某个位置,是不是通过key的hashCode()来计算的。其实,HashMap会根据这个key的hashCode来对我们的数据进行排序。为什么HashMap的key又是无序的,这个是因为hashCode是通过对应的变量在内存里面的地址计算出来。但是Integer的hashCode就是它自己。所以说,我们加入了Integer的key之后,HashMap会通过key从小到大给我们排序。
import java.io.*; import java.util.HashMap; import java.util.Map; import java.util.Set; /** * @ClassName TextCopyHashMap * @projectName: object1 * @author: Zhangmingda * @description: XXX * date: 2021/4/18. */ public class TextCopyBufferWriterHashMap { public static void main(String[] args) { String srcPath = "输入输出文件读写/src/test/output/沁园春雪-长沙.txt"; String dstPath = "输入输出文件读写/src/test/output/沁园春雪-长沙-HashMapSort.txt"; try(BufferedReader bufferedReader = new BufferedReader(new FileReader(srcPath)); BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter(dstPath))) { String tmpLine ; Map<Integer,String> textMap = new HashMap<>(); while ((tmpLine = bufferedReader.readLine()) != null){ String[] tmpLineArr = tmpLine.split("->"); Integer lineIndex = Integer.parseInt(tmpLineArr[0]); textMap.put(lineIndex,tmpLineArr[1]); } System.out.println(textMap); //{1=独立寒秋,湘江北去,橘子洲头。, 2=看万山红遍,层林尽染;, 3=漫江碧透,百舸争流。, 4=鹰击长空,鱼翔浅底,, 5=万类霜天竞自由。} for(Integer index : textMap.keySet()){ bufferedWriter.write(textMap.get(index)); bufferedWriter.newLine(); } /** * 独立寒秋,湘江北去,橘子洲头。 * 看万山红遍,层林尽染; * 漫江碧透,百舸争流。 * 鹰击长空,鱼翔浅底, * 万类霜天竞自由。 */ //复习Map.entrySet() 取值 Set entrySet = textMap.entrySet(); for(Object o : entrySet){ Map.Entry<Integer,String> a = (Map.Entry<Integer,String>)o; System.out.println(a.getKey() + a.getValue()); /** * 1独立寒秋,湘江北去,橘子洲头。 * 2看万山红遍,层林尽染; * 3漫江碧透,百舸争流。 * 4鹰击长空,鱼翔浅底, * 5万类霜天竞自由。 */ } }catch (FileNotFoundException e){ e.printStackTrace(); }catch (IOException e){ e.printStackTrace(); } } }
posted on 2021-04-18 14:08 zhangmingda 阅读(91) 评论(0) 编辑 收藏 举报