IO & NIO、select & poll & epoll

1.用户空间&内核空间

现在操作系统都是采用虚拟存储器,操作系统将虚拟空间划分为两部分,一部分为内核空间,一部分为用户空间。

1.1. 内核空间:受保护的内存空间,只有操作系统可以访问;
1.2. 用户空间:供应用程序使用;

2.当一个read操作发生时,它会经历两个阶段:

2.1. 程序操作io
2.2. 等待数据准备 (Waiting for the data to be ready)
2.3. 将数据从内核拷贝到进程中 (Copying the data from the kernel to the process)
2.4. io数据返回

3.阻塞&非阻塞

阻塞与非阻塞是针对于操作io后得到的返回结果而言。
非阻塞: 调用io后能立即得到返回应答,即不需要等待2.2 2.3操作;否则为阻塞;

4.同步&异步

同步:进程调用io后得到的返回值为需要的数据,不需要等待(2.2或2.3);
异步:调用io后得到的是数据状态(未准备完成等),内核操作完成后主动通知进程(之间不做任何轮询等操作);
  • 主要区别在于数据从内核空间拷贝到用户空间时,用户进程的状态;拷贝过程由io实现,进程不需要等待则为异步;否则为同步;

5.JAVA IO&NIO

IO:同步阻塞
NIO:同步非阻塞
AIO:也称为NIO2,异步非阻塞,jdk7

6.IO多路复用select、poll、epoll

这里“多路”指的是多个网络连接,“复用”指的是复用同一个线程

1.java网络编程使用IO,每一个链接都需要一个单独的线程(对java来说是线程)服务,没有通信时线程阻塞;
2.select模式,一个线程可以为多个链接服务(多路复用);
  a.所有链接都没有数据传输时,线程将其管理的所有连接(文件描述符)交给操作系统(描述符从用户空间复制到内核空间),由操作系统监控;进程阻塞;
  b.当其中有一个连接有数据传输时,操作系统通知线程(描述符从内核空间复制到用户空间)
  c.线程遍历所有连接(文件描述符)找到需要处理的连接;
2.1.主要缺点:
  a.单个线程能监控的连接(文件描述符)有限为1024;
  b.需要维护一个存放描述符的数据结构,内核与用户空间复制开销大;
  c.遍历描述符时线性扫描;
3.poll
  a.相比于select,取消了1024限制,但其他缺点仍然存在;
4.epoll
  a.取消1024限制;
  b.只将需要通信的连接返回给线程;
  c.目前只有linux支持
  1. BIO同步阻塞、NIO同步非阻塞,AIO为异步非阻塞

参考:Linux IO模式及 select、poll、epoll详解

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容