java 为什么要使用缓存?java中输入流去读取文件时为什么要创建一个缓存数组
这篇文章给大家聊聊关于java 为什么要使用缓存,以及java中输入流去读取文件时为什么要创建一个缓存数组对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。
...自定义一个数组来存储数据,为什么还要使用缓存区呢
IO流自定义字节流的缓冲区:
思路:BufferedInputStream类中read()方法的工作原理
1)先一个一个从字节流中读取字节,读取一定量(自定义)之后,存储在一个字节数组(缓冲区)(FileInputStream.read(byte[] b)),并获得存储数量(read方法的返回值)。
2)一个一个字节返回,返回一个,存储数量减1,然后指针往后移一位,准备取下一个。
3)如果存储数量为0,代表当前数组中所有数据已经全部取完,此时再来一次读取(read(byte[] b)),再获得此次存储数量。
4)如果存储数量(即read方法返回-1),代表读到文件末尾,返回-1。
因此,需要用到以下几个变量:
读取的字节数量,指向数组中准备取哪一个的指针,将要返回的字节变量。
什么是java中的"缓存"
我的观点,
象FileReader这样的比较低层的只能操作字节,而BufferedReader有
readLine()方法,返回的是一个String。而FileReader没有,我个人的理解:
开始创建BufferedReader时,FileReader被当作是一个参数,作为bufferedreader的一个实例变量保存着。当你调用bufferedreader.readLine()方法时,它就会调用filereader的read方法,一个一个地读字符,并且保存在它一块内存中,直到读到回车符,才将内容返回出来。这里两个类的区别在与FileReader的方法,你直接获取了数据,读出来的内容由你负责保存,而BufferedReader自己有内存保存一部分数据,你能调用他比较高级的readLine()方法来直接获取字符串
java中输入流去读取文件时为什么要创建一个缓存数组
IO流自定义字节流的缓冲区:
思路:BufferedInputStream类中read()方法的工作原理
1)先一个一个从字节流中读取字节,读取一定量(自定义)之后,存储在一个字节数组(缓冲区)(FileInputStream.read(byte[] b)),并获得存储数量(read方法的返回值)。
2)一个一个字节返回,返回一个,存储数量减1,然后指针往后移一位,准备取下一个。
3)如果存储数量为0,代表当前数组中所有数据已经全部取完,此时再来一次读取(read(byte[] b)),再获得此次存储数量。
4)如果存储数量(即read方法返回-1),代表读到文件末尾,返回-1。
因此,需要用到以下几个变量:
读取的字节数量,指向数组中准备取哪一个的指针,将要返回的字节变量。
什么是Java缓存技术Cache
java缓存技术
一、什么是缓存
1、Cache是高速缓冲存储器一种特殊的存储器子系统,其中复制了频繁使用的数据以利于快速访问
2、凡是位于速度相差较大的两种硬件/软件之间的,用于协调两者数据传输速度差异的结构,均可称之为 Cache
二、缓存的分类
1、基于web应用的系统架构图
2、在系统架构的不同层级之间,为了加快访问速度,都可以存在缓存
操作系统磁盘缓存->减少磁盘机械操作
数据库缓存->减少文件系统I/O
应用程序缓存->减少对数据库的查询
Web服务器缓存->减少应用服务器请求
客户端浏览器缓存->减少对网站的访问。
OK,关于java 为什么要使用缓存和java中输入流去读取文件时为什么要创建一个缓存数组的内容到此结束了,希望对大家有所帮助。