java bio总结
、同步异步、阻塞非阻塞(目前不是很清楚,这篇博客写完后,后续进行处理)
1.同步和异步:关注的是消息的通讯机制,
同步:发起调用后,如果没有得到结果,该调用是不会返回的;该调用者会主动等待调用返回。
异步:发起调用后,调用立刻返回,但并不是返回的结果;也就是说调用者并不会立刻得到结果,而是被调用者通知调用者,或者通过回调函数处理这个调用。
2.阻塞和非阻塞:指的是程序等待调用结果时的状态。只有同步才会有阻塞和非阻塞的概念。
阻塞:发起调用后当前线程会被挂起,直到有返回
非阻塞:发起调用后,当前线程不会被挂起,而是继续执行。
二、io流的分类
1.输入流、输出流:根据流是否流向处理器来确定是输入流还是输出流。
2.字节流、字符流:字节流读到的数据不会进行任何处理;字符流读取到的二进制数据会根据相应的编码进行转换为字符,字符流=字节流+解码。
三、io流类结构图


四、常用功能
注意一点:使用完io后,一定要关闭流
1.io流对文件进行读取
/**
* 字符流读写文本文件
* 在使用io读写文本文件的时候一定要记住关闭流
*/
public class Test2 { public static void main(String[] args) {
ReadFile(new File("E:/b.txt"));
WriteFile(new File("E:/c.txt"));
} public static void ReadFile(File file){
FileReader fr = null;
BufferedReader br = null;
InputStreamReader isr = null;
try { System.out.println("\r\n========自己定义缓冲数组来读取文件================");
fr = new FileReader(file);
char[] buffer1 = new char[3];
int len1 = 0;
while((len1 = fr.read(buffer1)) != -1){
System.out.print(new String(buffer1,0,len1));
} System.out.println("\r\n========使用缓冲流来读取文件================");
br = new BufferedReader(new FileReader(file));
String temp = "";
while((temp = br.readLine()) != null){
System.out.println(temp);
} System.out.println("\r\n========使用转换流来读取文件===========");
isr = new InputStreamReader(new FileInputStream(file),"utf-8");
char[] buffer2 = new char[1];
int len2 = 0;
while((len2 = isr.read(buffer2)) != -1 ){
System.out.print(new String(buffer2,0,len2));
} } catch (FileNotFoundException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
br.close();
isr.close();
} catch (IOException e) {
e.printStackTrace();
}
} } public static void WriteFile(File file){
FileOutputStream fos = null;
FileWriter fw = null;
BufferedWriter bw = null;
try {
//========使用字节流写入文件===========
fos = new FileOutputStream(file);
fos.write("测试写入文件abc123。。".getBytes());
fos.write("测试是否叠加".getBytes());
fos.flush();
//========使用字符流写入文件===========
fw = new FileWriter(file,true);
fw.write("\r\n========使用字符流写入文件===========");
fw.write("这是用FileWriter写入的数据 ");
fw.flush();
//========使用缓冲流写入文件===========
//FileWriter默认是会覆盖上一次的数据,所以在新建的时候要将是否追加参数设置为true
bw = new BufferedWriter(new FileWriter(file,true));
bw.newLine();
bw.write("使用缓冲流写入");
bw.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (NumberFormatException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
bw.close();
fw.close();
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
} }
2.字节流对文件进行复制
/**
* 字节流对文件进行复制
*
*/
public class Test1 { public static void main(String[] args) throws IOException {
copy();
} public static void copy(){
FileInputStream fis = null;
FileOutputStream fos = null;
try{
fis = new FileInputStream("E:/a.txt");
fos = new FileOutputStream("E:/b.txt");
byte[] buffer = new byte[1024];//使用数组进行缓冲,提高io速度
int len = 0;
while((len = fis.read(buffer)) != -1){
fos.write(buffer, 0, len);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
try {
fis.close();
} catch (IOException e) {
e.printStackTrace();
} }
}
}
五、IO流使用的一些细节
1.IO流中,缓冲类都是Buffered*类,其并不具备读写能力,只是内部维护了一个8kb的数组,只有在调用了close()和flush()或者字节数组已经满了才会将数据写入到硬盘。提高了文件的读写效率。
2.文件输出流,目标文件如果不存在,则会创建文件。其write方法默认清空文件内容,再写入内容,需要在构造方法中设置才能成功。
3.FileOutputStream 参数为int时,只会把低8位写出,剩余24位丢弃。
4.转换流的作用就是将字节流转换为字符流,并可以按照指定的编码对数据进行读写。
java bio总结的更多相关文章
- Java BIO、NIO、AIO 学习(转)
转自 http://stevex.blog.51cto.com/4300375/1284437 先来个例子理解一下概念,以银行取款为例: 同步 : 自己亲自出马持银行卡到银行取钱(使用同步IO时,Ja ...
- JAVA bio nio aio
[转自]http://qindongliang.iteye.com/blog/2018539 在高性能的IO体系设计中,有几个名词概念常常会使我们感到迷惑不解.具体如下: 序号 问题 1 什么是同步? ...
- Java BIO、NIO、AIO-------转载
先来个例子理解一下概念,以银行取款为例: 同步 : 自己亲自出马持银行卡到银行取钱(使用同步IO时,Java自己处理IO读写). 异步 : 委托一小弟拿银行卡到银行取钱,然后给你(使用异步IO时,Ja ...
- Java BIO、NIO、AIO 学习
正在学习<大型网站系统与JAVA中间件实践>,发现对BIO.NIO.AIO的概念很模糊,写一篇博客记录下来.先来说个银行取款的例子: 同步 : 自己亲自出马持银行卡到银行取钱(使用同步IO ...
- JAVA BIO与NIO、AIO的区别
IO的方式通常分为几种,同步阻塞的BIO.同步非阻塞的NIO.异步非阻塞的AIO. 一.BIO 在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个ServerSock ...
- 3. 彤哥说netty系列之Java BIO NIO AIO进化史
你好,我是彤哥,本篇是netty系列的第三篇. 欢迎来我的公从号彤哥读源码系统地学习源码&架构的知识. 简介 上一章我们介绍了IO的五种模型,实际上Java只支持其中的三种,即BIO/NIO/ ...
- [转帖]JAVA BIO与NIO、AIO的区别(这个容易理解)
JAVA BIO与NIO.AIO的区别(这个容易理解) https://blog.csdn.net/ty497122758/article/details/78979302 2018-01-05 11 ...
- Java BIO、NIO、AIO 原理
先来个例子理解一下概念,以银行取款为例: 同步 : 自己亲自出马持银行卡到银行取钱(使用同步IO时,Java自己处理IO读写). 异步 : 委托一小弟拿银行卡到银行取钱,然后给你(使用异步IO时,Ja ...
- Java BIO、NIO、AIO 基础,应用场景
Java对BIO.NIO.AIO的支持: Java BIO : 同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必 ...
- Java BIO NIO 与 AIO
回顾 上一章我们介绍了操作系统层面的 IO 模型. 阻塞 IO 模型. 非阻塞 IO 模型. IO 复用模型. 信号驱动 IO 模型(用的不多,知道个概念就行). 异步 IO 模型. 并且介绍了 IO ...
随机推荐
- java json转换(一)
主要使用了2个类 JsonConvert.class 和 ConvertHelper.class 由于常规转json.只要model牵涉到复杂的关联实体对象.那么就会出现 深度循环的错误. 因此这里通 ...
- Matplotlib学习---用matplotlib和sklearn画拟合线(line of best fit)
在机器学习中,经常要用scikit-learn里面的线性回归模型来对数据进行拟合,进而找到数据的规律,从而达到预测的目的.用图像展示数据及其拟合线可以非常直观地看出拟合线与数据的匹配程度,同时也可用于 ...
- 如何让自己定义的memory使用fpga自带的memory资源
前言 本文解决方法来源: http://quartushelp.altera.com/13.1/mergedProjects/hdl/vlog/vlog_file_dir_ram.htm 如果你自己V ...
- studio 连不上远程仓库的各种原因分析
Unable to open the project 1.远程服务器挂了2.网络断了3.登录远程服务器的账号.密码错了4.远程仓库的url地址,被本地的hosts文件重定向了5.要下载远程仓库的某个j ...
- 后台CRUD管理jqGrid 插件下载、使用、demo演示
jqGrid:demo?version=5.2.1download src: http://www.trirand.com/blog/ github:https://github.com/tonyto ...
- HDOJ5551 Huatuo's Medicine
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5551 题目大意:... 题目思路:乱搞?模拟? #include <stdio.h> vo ...
- hiho1258 Osu! Master
题目链接:http://hihocoder.com/problemset/problem/1258 题目大意:看能连击的次数 思路:水 看有多少个1和s就好了 #include <stdio.h ...
- MT【257】任意存在并存
函数$f(x)=\dfrac{4x}{x+1}(x>0),g(x)=\dfrac{1}{2}(|x-a|-|x-b|),(a<b)$, 若对任意$x_1>0$,存在$x_2\le x ...
- 【Luogu3732】[HAOI2017]供给侧改革(Trie树)
[Luogu3732][HAOI2017]供给侧改革(Trie树) 题面 洛谷 给定一个纯随机的\(01\)串,每次询问\([L,R]\)之间所有后缀两两之间的\(LCP\)的最大值. 题解 一个暴力 ...
- [算法进阶0x10]基本数据结构C作业总结
t1-Supermarket 超市利润 题目大意 给定n个商品,每个商品有利润pi和过期时间di.每天只能卖一个商品,过期商品不能卖.求如何安排每天卖的商品可以使收益最大. 分析 一开始打了一个复杂度 ...