java io为什么重要

互联网 19-5-29
Java的IO流是实现输入/输出的基础,它可以方便地实现数据的输入/输出操作,在Java中把不同的输入/输出源抽象表述为"流"。

流是一组有顺序的字节集合,是对数据传输的总称或抽象。

流有输入和输出,输入时是流从数据源流向程序。输出时是流从程序传向数据源,而数据源可以是内存,文件,网络或程序等。

用户进程和操作系统内核

程序空间和内核空间

Waiting for the data to be ready(等待数据到达内核缓冲区)

Copying the data from the kernel to the process(从内核缓冲区拷贝数据到程序缓冲区)

在Linux中,对于一次读取IO的操作,数据并不会直接拷贝到程序的程序缓冲区。

它首先会被拷贝到操作系统内核的缓冲区中,然后才会从操作系统内核的缓冲区拷贝到应用程序的缓冲区。

程序空间:分配给用户程序的内存空间。

内核空间:内核拥有的内存空间。

阻塞和非阻塞

阻塞:用户进程进行系统调用后,用户进程一直处于锁定的状态,不能进行其他操作

非阻塞:用户进程进行系统调用后,用户进程没有被锁定,可以进行其他操作

阻塞和非阻塞说的是用户进程的状态,即用户进程是否被锁定

同步和异步

一个同步的io操作会导致发起请求的进程阻塞直到这个io操作完成。一个异步的io操作不会导致请求的线程被阻塞。

同步:用户线程和io线程做同一件事(用户线程被阻塞,等待内核返回处理结果)

异步:用户线程和io线程做不同的事情(用户线程不被阻塞,做其他的事情,内核处理完成发送结果给用户线程)

文件描述符

在Linux下面一切皆文件。文件描述符(file descriptor)是内核为文件所创建的索引,所有I/O操作都通过调用文件描述符(索引)来执行,包括下面我们要提到的socket。Linux刚启动的时候会自动设置0是标准输入,1是标准输出,2是标准错误。

以上就是java io为什么重要的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: java
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:java学到什么程度可以工作

相关资讯