1.默认模式(LT)的epoll服务器代码
vim myepoll.c
运行结果如下:
2.epoll 服务器的优缺点
优点:
1)支持最大数目的文件描述符(fd)
epoll 的文件描述符支持最大的打开数目,一般来说 1G 可以存 10 万左右。
2)IO 效率不随 fd 数目增加下降
这个主要原因是因为 epoll 不采用轮询,采用活跃的 fd 进行调用 callback 回调机制实现的。
3)mmap实现
epoll 的实现中使用了 mmap (内存)映射机制,这样可以避免不必要的内存拷贝,用户空间和内核空间在同一块内存实现,避免了多余的拷贝,省掉了这些文件描述符在系统调用时复制的开销。
缺点:
1)相对 select 来说,epoll 的跨平台性不够用,只能工作在 Linux 下,而 select 可以在 windows linux apple 上使用,还有手机端 Android iOS 之类的都可以。 android 虽然是 linux 的内核,但早期版本同样不支持 epoll 的。
2)相对 select 来说,还是用起来还是复杂了一些,不过和 IOCP 比起来,增加了一点点的复杂度却基本上达到了 IOCP 的并发量和性能,而复杂度远远小于IOCP。
3)相对 IOCP 来说,对多核/多线程的支持不够好,也因此在性能要求比较苛刻的情况下不如 IOCP。