高级IO

非阻塞IO,
记录锁,
系统V流机制,
IO多路转接,
readv和writev
存储映射IO(mmap)

pipe/socketpair

pipe用来创建单向通信管道
socketpair用来创建双向通信管道.

int socketpair(int domain, int type, int protocol, int sv[2]);

dup/dup2

对输入文件描述符重定向

int dup(int oldfd);

int dup2(int oldfd, int newfd);

I/O多路转接之select

系统提供select函数实现多路复用输入输出模型.select系统调用让我们的程序监视多个文件句柄的状态变化.程序停在select等待,直到被监视的文件句柄有一个或者多个发生了状态改变.

文件句柄是一个整数,对应FILE*结构.

int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set *exceptfds, struct timeval *timeout);

void FD_CLR(int fd, fd_set *set);

int  FD_ISSET(int fd, fd_set *set);

void FD_SET(int fd, fd_set *set);

void FD_ZERO(fd_set *set);

参数说明:
hfds是需要监视的最大文件描述符值+1;
rdset,wrset,exset分别对应需要检测的文件描述符集合,可写,可读,异常
struct timeval 结构用于描述一段时间长度,如果时间内,需要监视的描述符咩有事件发生则函数返回
宏分别提供了检测功能.

struct timeval {
long    tv_sec;        /* seconds */
long    tv_usec;        /* microseconds */
};

timeout参数:

NULL:表示select没有timeout,一直被阻塞,直到某个事件发生.
0;仅检测描述符集合的状态,然后立即返回,并不等待外部事件的发生.
特定时间值:如果指定时间内没有事件发生,select超时返回

函数返回值

执行成功返回描述符状态已改变的个数
如果返回0表示在描述词状态改变前已经超时timeout时间,没有返回;
当错误发生时返回-1,错误原因errno

select特点:

1可以监控的文件描述符个数取决于sizeof(fd_set)
2将fd加入select监控集合的同时,还要使用一个数据结构array保存放到select监控集合中的fd,
一是用于在select返回后,array作为源数据和FD_ISSET判断.
二是select返回后会把以前加入的但并无事件发生的fd清空,则每次都重新从array取得fd依次加入,扫描获取最大maxfd,用于第一个参数
3可见select模型必须在select前循环array(加入fd,取maxfd),select返回后循环array(判断FD_ISSET是否有事件发生)

select缺点

1)每次调用select都要把fd集合从用户态拷贝到内核态,这个开销在fd很多时很大
2)每次调用select都需要内核遍历传递进来的所有fd
3)select支持的文件描述符数量太小,默认1024

I/O多路转接之poll

不同于select使用三个位图表示三个fdset的方式,poll使用一个pollfd的指针来实现

int poll(struct pollfd *fds, nfds_t nfds, int timeout);
struct pollfd {
    int  fd;        /* file descriptor */ 
    short events;    /* requested events */
    short revents;    /* returned events */
};

结构包含要监视的event和发生的event,不再使用select"参数-值"传递方式.同时poll并没有最大数量限制
同select,poll返回后,需要轮询pollfd来获取就绪的描述符

I/O多路转接之epoll

为处理大批量句柄而改进的poll.

int epoll_create(int size);

int epoll_ctl(int epdf,int op, int fd, struct epoll_event* event);

事件注册函数,不同于select在监听事件时告诉内核要监听什么类型事件,而是在这里先注册要监听的事件类型
第一个参数为create的返回值
第二个参数表示动作:
EPOLL_CTL_ADD:注册新fd到epfd中;
EPOLL_CTL_MOD:修改已经注册的监听事件
EPOLL_CTL_DEL:从epfd中删除一个fd
第三个参数是需要监听的fd
第四个参数告诉内核需要监听什么事:
typedef union epoll_data {
void        *ptr;
int          fd;
uint32_t    u32;
uint64_t    u64;
} epoll_data_t;
struct epoll_event {
uint32_t    events;      /* Epoll events */
epoll_data_t data;        /* User data variable */
};

events可以是以下几个宏的集合
EPOLLIN:表示对应的文件描述符可读(包含对端socket正常关闭)
EPOLLOUT:可写
PRI:表示对应文件描述符有紧急的数据可读(这里应该表示有外来数据到来)
ERR:错误
HUP:表示对应的文件描述符被挂起
EPOLLET:将EPOLL设置为边缘触发模式(Edge Triggered),相对于LT
EPOLLONESHOT:只监听一次事件,当监听完这次事件之后,如果还需要监听这个socket,需要从新将socket加入EPOLL队列\

int epoll_wait(int epfd,struct epoll_event*events,int maxevenets,int timeout);

手机在epoll监控的事件已经发生的事件.参数events是分配好的epoll_event结构题数组,(event不可以是控制真,内核hafiz巴蜀据复制到event数组中,不会帮我们在用户态分配内存)maxevent告内之内核这个event有多大,这个maxevent的值不能超过epoll_creae时的size,参数timeout超时时间
如果函数调用成功,返回对应IO上准备好的文件描述符数目,返回0表示超时

epoll工作原理

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

推荐阅读更多精彩内容