ioLinux C编程之非阻塞IO实践(linuxc非阻塞)
IO(Input/Output),即输入输出,包括网络IO,文件IO,外设IO等
Linux C编程中的非阻塞IO实践,指的是使用通用的Linux C/C++ API接口,实现在操作系统上的非阻塞IO,类似于select机制,也就是应用层程序应使用select或者poll机制发出IO请求。接着,系统会在请求的某些IO资源上确定就绪,该IO资源就绪意味着可以继续读取或者编写一些数据,这个过程实际上不再涉及系统调用来完成操作,程序只需不断地检查是否有某个资源准备好,这样则可避免低效的系统调用。
在实现Linux C编程中的非阻塞IO实践时,可以使用如下函数来实现:
1. select:可以对多个文件描述符(文件句柄),实现IO多路复用,socket可以使用这种方式,查看哪个socket可以进行IO操作
2. poll:类似于select,是一种更高效的IO多路复用机制
3. epoll:是Linux提供的一种高效的IO多路复用机制,可以达到更好的性能
以下是一个示例代码:
#include
// 返回epoll实例描述符
int epoll_create(){
epoll_fd = epoll_create(1);
if (epoll_fd
return -1;
}
return epoll_fd;
}
// 向epoll实例中添加文件描述符
void epoll_add(int epoll_fd, int fd, void *data){
struct epoll_event ev;
ev.data.ptr = data;
ev.events = EPOLLIN | EPOLLOUT | EPOLLET;
if (epoll_ctl(epoll_fd, EPOLL_CTL_ADD, fd, &ev) == -1){
// 添加失败处理
}
return;
}
// 从epoll实例中删除文件描述符
void epoll_del(int epoll_fd, int fd){
epoll_ctl(epoll_fd, EPOLL_CTL_DEL, fd, 0);
return;
}
Epoll机制可以在实现Linux代码中,用于实现高效率地非阻塞IO。通过epoll_create、epoll_add、epoll_del接口将文件描述符添加到epoll实例中,使得该文件描述符关联的IO可以多路复用。通过epoll_wait可以获取就绪的文件描述符,当有多个文件描述符就绪时,堆进程只需处理一个就绪文件描述符即可,进而可以实现高效率地非阻塞IO。