您的位置:首页 > 其它

I/O 设计模型

2017-12-16 00:00 148 查看
参考资料:https://www.cnblogs.com/myJavaEE/p/6721127.html

https://www.cnblogs.com/wade-luffy/p/5680327.html

同步:就是按顺序操作,一直等待响应

异步:发起异步后,接下来的顺序还可以继续执行,后台通过回调获取结果

阻塞:是后台进程由于io过程时间长而挂起,没返回数据,直到io完成,调度到此

进程,而后返回结果

非阻塞:后台进程即时返回当前io信息,io完成后,调度到此进程,而后返回结果

同步阻塞io: 用户一直等待后台进程返回的信息,不能进行其他的操作

同步非阻塞:类似 加了循环的同步阻塞io,不断循环请求结果,(假象,假的非阻塞)

同步 io多路复用: 也是类似 加了循环的同步阻塞io,但是,属于优化版的,使用

系统函数select、epoll;注册,有结果后,通知激活socket,通过select返回数据,

然后用户就可以read数据 (此属于 reactor 设计模式)

异步io:在异步io模型中,当用户线程收到通知后,数据已经被操作系统从内核拷

贝到指定的缓冲区中,用户线程直接使用即可。看似 io多路复用的加强版,(此属

于proactor设计模式)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  I/O Docs