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 ...
随机推荐
- jQuery 操作input select,checkbox
input $("#add_device_owner_id").val() $("#add_device_owner_id").val("d" ...
- DRF 视图和路由
Django Rest Feamework 视图和路由 DRF的视图 APIView 我们django中写CBV的时候继承的是View,rest_framework继承的是APIView,那么他们两个 ...
- 洛谷P1550打井
打井 题目 该题是一个最小生成树的好题,但是比起一般的最小生成树来说他不仅仅有各个井相连,而且还要和地下水相连,所以地下水我们也可以看成一口井. 代码 #include <bits/stdc++ ...
- FPGA笔试题集锦(血的教训)
1.名词解释: FPGA:现场可编程门阵列,一般工艺SRAM(易失性),所以要外挂配置芯片. CPLD:复杂可编程逻辑器件,一般工艺Flash(不易失). ASIC:专用集成电路 SOC:片上系统 S ...
- php+redis配置
系统环境: win10+phpstudy+lamp 安装扩展 php5.6.4 =>下载地址:http://windows.php.net/downloads/pecl/releases/red ...
- 【宝塔linux】 导入mysql 大文件失败的问题
导入数据库有四种方法 1.宝塔网站自带的数据库导入 2.phpmyadmin导入 3.远程到linux服务器用导入命令 使用xshell进入到控制台 1.首先建空数据库 mysql>create ...
- 「CodeForces - 598B」Queries on a String
BUPT 2017 summer training (for 16) #1I 题意 字符串s(1 ≤ |s| ≤ 10 000),有m(1 ≤ m ≤ 300)次操作,每次给l,r,k,代表将r位置插 ...
- 如何改变Android标准键的颜色?
本文选自StackOverflow(简称:SOF)精选问答汇总系列文章之一,本系列文章将为读者分享国外最优质的精彩问与答,供读者学习和了解国外最新技术,本文为大家讲解如何改变Android标准键的颜色 ...
- [学习笔记]FWT——快速沃尔什变换
解决涉及子集配凑的卷积问题 一.介绍 1.基本用法 FWT快速沃尔什变换学习笔记 就是解决一类问题: $f[k]=\sum_{i\oplus j=k}a[i]*b[j]$ 基本思想和FFT类似. 首先 ...
- 只用200行Go代码写一个自己的区块链!
Coral Health · 大约23小时之前 · 220 次点击 · 预计阅读时间 7 分钟 · 不到1分钟之前 开始浏览 区块链是目前最热门的话题,广大读者都听说过比特币,或许还有智能合约,相信大 ...