18 IO

问题

介绍一下java中的IO

答案

  • 冯诺依曼体系结构约束了计算机要包括存储设备、控制器、运算器、输入设备和输出设备等五大部分。java中的IO指的是在数据在内存、硬盘和输入设备输出设备之间的流转。I(Input)多只硬盘数据读到内存;O(Output)多指内存数据写到硬盘。
  • java中的IO相关的类或者接口包括:
    File: 映射文件系统
    InputStream:字节输入流
    OutputStream:字节输出流
    Reader:字符输入流
    Writer:字符输出流
    BufferedReader:缓冲输入流
    BufferedWriter:缓冲输出流
    RandomAccessFile:随机流
  • BIO(Blocking I/O 同步阻塞): 需要先在服务端启动一个ServerSocket,然后在客户端启动Socket来对服务端进行通信,默认情况下服务端需要对每个请求建立一个线程。客户端发送请求后,先看服务端是否有线程响应,如果没有则会一直等待或者遭到拒绝请求;如果有,客户端线程会在等待结束后才继续执行。BIO方式适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用中,JDK1.4以前的唯一选择,但程序直观简单易理解。
  • NIO(Non-blocking I/O 同步非阻塞): 基于Reactor,当socket有流可读或可写入socket时,操作系统会相应的通知应用程序进行处理,应用再将流读取到缓冲区或写入操作系统。此时,已经不是一个连接就要对应一个处理线程了,而是有效的流请求,对应一个线程,当连接没有数据时,是没有工作线程来处理的。NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持。
  • AIO(Asynchronous I/O 异步非阻塞): 当进行读写操作时,只须直接调用API的read或write方法即可。这两种方法均为异步的,对于读操作而言,当有流可读取时,操作系统会将可读的流传入read方法的缓冲区,并通知应用程序;对于写操作而言,当操作系统将write方法传递的流写入完毕时,操作系统主动通知应用程序,即read/write方法都是异步的,完成后会主动调用回调函数。AIO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值