I/O浅析
1.为什么需要I/O?
因为程序需要从别的文件中获取内容或者程序要将自身的内容传入到文件中。
2.流种类的概述
1.字节流和字符流
字节流的基础单位是byte 字符流的基础单位是char
2.InputStream和OutputStream
InputStream:外部文件内容输入到程序 OutputStream:程序内容输出到外部文件
3.基础流:各种扩展的InputStream和OutputStream流
每种扩展的形式分别处理不同的文件 (不一一展开,到后面详解一种)
4.处理流:安装在基础流上的流
以InputStream和OuputStream为基础,对I/O进行装饰。(就像在基础管道上套了一层管道,然后有了新的功能)。(不展开,后面详解最主要用到的)
3.流的主要方法和运行原理(主讲InputStream/OutputStream Reader和Writer原理一致)
InputStream:
public abstract int read()
throws IOException
//运行原理:每访问一次指针下移一字节,int返回该自己的int类型(0-255),当到达文件末尾时候返回-1
public int read(byte[] b)
throws IOException
//运行原理,将读取到的自己存入byte[] b中(b存满为止),然后指针下移到b存满的位置,int返回多少字节存入byte[]中,若到达文件末尾返回-1
OutputStream:
public int write(byte[] b)
throws IOException
//运行原理:将byte[] b中的字节输出到外部文件。
4.基础流讲解(FileInputStream和FileOutputStream)
1.基础知识File类
作用:获取文件的句柄,并可获取文件的相关信息
创建:File file = new File(String path);
2.FileInputStream和FileOutputStream的创建
FileInputStream is = new FileInputStream(File file); FileInputStream os = new FileOutputStream(File file);
所以:基础流是用来:获取不同文件的inputStream和outputStream。
3.处理流:BufferedInputStream
1.原理
作用:将从InputStream获得的字节,放入到一个32字节的缓冲区中,能够让获取的字节按照每一行输出且以String形式。
问题:如果缓冲区没满,不会将缓存到其中的字节输出。
2.使用
InputStream is = new InputStream();
BufferedInputStream bis = new BufferedInputStream(is);
//在InputStream上套了一层
String builder = new String buidler(); //具有缓冲性质的String类型
while((String s = bis.readLine()) != null){ //readLine() 返回 String类型,若到达文件尾部返回Null
builder.append(s);
bis.flush() //将缓存中的字节强制输出
}
I/O浅析的更多相关文章
- SQL Server on Linux 理由浅析
SQL Server on Linux 理由浅析 今天的爆炸性新闻<SQL Server on Linux>基本上在各大科技媒体上刷屏了 大家看到这个新闻都觉得非常震精,而美股,今天微软开 ...
- 【深入浅出jQuery】源码浅析--整体架构
最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...
- 高性能IO模型浅析
高性能IO模型浅析 服务器端编程经常需要构造高性能的IO模型,常见的IO模型有四种: (1)同步阻塞IO(Blocking IO):即传统的IO模型. (2)同步非阻塞IO(Non-blocking ...
- netty5 HTTP协议栈浅析与实践
一.说在前面的话 前段时间,工作上需要做一个针对视频质量的统计分析系统,各端(PC端.移动端和 WEB端)将视频质量数据放在一个 HTTP 请求中上报到服务器,服务器对数据进行解析.分拣后从不同的 ...
- Jvm 内存浅析 及 GC个人学习总结
从诞生至今,20多年过去,Java至今仍是使用最为广泛的语言.这仰赖于Java提供的各种技术和特性,让开发人员能优雅的编写高效的程序.今天我们就来说说Java的一项基本但非常重要的技术内存管理 了解C ...
- 从源码浅析MVC的MvcRouteHandler、MvcHandler和MvcHttpHandler
熟悉WebForm开发的朋友一定都知道,Page类必须实现一个接口,就是IHttpHandler.HttpHandler是一个HTTP请求的真正处理中心,在HttpHandler容器中,ASP.NET ...
- 【深入浅出jQuery】源码浅析2--奇技淫巧
最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...
- 浅析匿名函数、lambda表达式、闭包(closure)区别与作用
浅析匿名函数.lambda表达式.闭包(closure)区别与作用 所有的主流编程语言都对函数式编程有支持,比如c++11.python和java中有lambda表达式.lua和JavaScript中 ...
- word-break|overflow-wrap|word-wrap——CSS英文断句浅析
---恢复内容开始--- word-break|overflow-wrap|word-wrap--CSS英文断句浅析 一 问题引入 今天在再次学习 overflow 属性的时候,查看效果时,看到如下结 ...
- 编写轻量ajax组件02-AjaxPro浅析
前言 上一篇介绍了在webform平台实现ajax的一些方式,并且实现一个基类.这一篇我们来看一个开源的组件:ajaxpro.虽然这是一个比较老的组件,不过实现思想和源码还是值得我们学习的.通过上一篇 ...
随机推荐
- html ul li 显示数据库
方法1: function insert() { var str=""; var data="你的数据库数据"; str="<ul>< ...
- silverlight中鼠标放在对象的提示事件
1.xaml 中实现 <Rectangle x:Name="toolTip" Grid.Column="0" Grid.Row="1" ...
- (原)JNI中env->GetByteArrayElements和AndroidBitmap_getInfo的冲突
也不是很确定,前段时间的代码没有出问题,但是今天调试了半天,一直崩溃:vm aborting. 以前的部分代码: JNIEXPORT void JNICALL XXX (JNIEnv* env,job ...
- 【Android 错误记录】installation error: INSTALL_PARSE_FAILED_NO_CERTIFICATES 错误
在运行android应用的时候报出了如题的错误: installation error: INSTALL_PARSE_FAILED_NO_CERTIFICATES 原因之一:在src源文件目录下面,有 ...
- Oracle RETURNING INTO 用法示例 .
The RETURNING INTO clause allows us to return column values for rows affected by DML statements. The ...
- python 的内建函数
lambda 函数:lambda语句中,冒号前是参数,可以有多个,用逗号隔开,冒号右边的返回值 1. map/reduce 函数 (1)map()函数接收两个参数,一个是函数,一个是序列,map将传入 ...
- 定制化Azure站点Java运行环境(5)
Java 8下PermGen及参数设置 在上一章节中,我们定制化使用了Java 8环境,使用我们的测试页面打印出了JVM基本参数,但如果我们自己观察,会发现在MXBeans中,没有出现PermGen的 ...
- Hbase深入学习(一) 什么是hbase
Hbase深入学习(一) 什么是hbase 一.hbase是什么? 首先hbase是一个在Hadoop的HDFS分布式存储系统上介于映射(key/value)的nosql的分布式数据库:它通 ...
- JS:函数多个参数默认值指定
函数有一个参数时,以往这样定义(参数为p1): function mfun(p1){ … } 当需要为p1设定一个默认值时 function mfun(p1){ if(p1===undefined) ...
- linux之SQL语句简明教程---UNION
UNION 指令的目的是将两个 SQL 语句的结果合并起来.从这个角度来看, UNION 跟 JOIN有些许类似,因为这两个指令都可以由多个表格中撷取资料. UNION 的一个限制是两个 SQL 语句 ...