I/O本质:对数据的读写操作
I/O分类:
(1)BIO:同步阻塞的IO
(2)NIO:同步非阻塞IO
(3)AIO:异步非阻塞IO
I/O的方式:
(1)网络IO
(2)本地文件IO
I/O读写方式:
I/O特性:
(1)本质上属于数据传输
(2)涉及两个设备间数据的传送方向
(3)是数据流 (数据在不同设备之间流转)
(4)Java进程的IO操作对进程影响:
- 阻塞IO(BIO)会导致进程在运行态和阻塞态转换,由操作系统完成后续的IO操作
- Java进程,在内核态和用户态切换,性能降低
(5)特殊内容
IO缓冲流——系统缓冲区、Java进程的内存
注意使用/不使用缓冲区的区别:
例如:循环10000次,每次write 1 个字节数据到本地文件
若不使用缓冲区:每次循环都是IO操作,都涉及进程状态由运行态转变为阻塞态,由用户态转变为内核态(10000次影响),效率更高
若使用缓冲区:每次循环write复制数据到缓冲区,flush才算IO操作(一次影响),性能更好