libuv 与 libev 的对比
libuv 与 libev 的对比
05 January 2013libuv 和 libev ,两个名字相当相近的 I/O Library,最近有幸用两个 Library 都写了一些东西,下面就来说一说我本人对两者共同与不同点的主观表述。
高性能网络编程这个话题已经被讨论烂了。异步,异步,还是异步。不管是
epoll也好,kqueue也罢,总是免不了异步这个话题。libev 是系统异步模型的简单封装,基本上来说,它解决了
epoll,kqueuq与select之间 API 不同的问题。保证使用livev的 API 编写出的程序可以在大多数 *nix 平台上运行。但是libev的缺点也是显而易见,由于基本只是封装了 Event Library,用起来有诸多不便。比如accept(3)连接以后需要手动setnonblocking。从 socket 读写时需要检测EAGAIN、EWOULDBLOCK和EINTER。这也是大多数人认为异步程序难写的根本原因。libuv 则显得更为高层。
libuv是 joyent 给 Node 做的一套 I/O Library 。而这也导致了libuv最大的特点就是处处回调。基本上只要有可能阻塞的地方,libuv都使用回调处理。这样做实际上大大减轻了程序员的工作量。因为当回调被 call 的时候,libuv保证你有事可做,这样EAGAIN和EWOULDBLOCK之类的 handle 就不是程序员的工作了,libuv会默默的帮你搞定。libev 在 socket 发生读写事件时,只告诉你,“XX socket 可以读/写了,自己看着办吧”。往往我们需要自己申请内存并调用
read(3)或者write(3)来响应 I/O 事件。libuv 则稍微复杂一些,我们分读/写两个部分来描述。
当接口可读时,
libuv会调用你的 allocate callback 来申请内存并将读到的内容写入。当读取完毕后,libuv会 call 你为这个 socket 设置的回调函数,在参数中带着这个 buffer 的信息。你只需要负责处理这个 buffer 并且free掉就OK了。因为是从 buffer 中读取数据,在你的 callback 被调用时数据已经 ready 了,所以程序员也就不用考虑阻塞的问题了。而对写的处理则更显巧妙。
libuv没有 write callback ,如果你想写东西,直接 generate 一个 write request 连着要写的 buffer 一起丢给libuv,libuv会把你的 write request 加进相应 socket 的 write queue ,在 I/O 可写时按顺序写入。C 没有闭包,所以确定读写上下文是
libuv的使用者需要面对的问题。否则程序面对汹涌而来的 buffer 也不能分得清哪个是哪个的数据。在这一点的处理上,libuv跟libev一样,都是使用了一个void *data来解决问题。你可以用 data 这个 member 存储任何东西,这样当 buffer 来的时候,只需要简单的把 data cast 到你需要的类型就 OK 了。libev 没有异步 DNS 解析,这一点一直广为垢病。
libuv 有异步的 DNS 解析,解析结果也是通过回调的方式通知程序。
libev 完全是单线程的。
libuv 需要多线程库支持,因为其在内部维护了一个线程池来 handle 诸如
getaddrinfo(3)这样的无法异步的调用。libev 貌似是作者一个人在开发,版本管理使用的还是 CVS ,社区参与度明显不高。
libuv 社区十分活跃,几乎每天都有人提出 Issue 并贡献代码。
libev 不支持
IOCP,如果需要在 Win 下运行的程序会很麻烦。libuv 支持
IOCP,有相应脚本编译 Win 下的库。
libuv 与 libev 的对比的更多相关文章
- libuv和libev 异步I/O库的比较
libuv 和 libev ,两个名字相当相近的 I/O Library,最近有幸用两个 Library 都写了一些东西,下面就来说一说我本人对两者共同与不同点的主观表述. 高性能网络编程这个话题已经 ...
- 负载均衡 IO etc.
IO多路复用之epoll总结 ↑2013年8月21日11:49:44 EPOLL下的accept(不错的blog) 关于TCP封包.粘包.半包 linux内核TCP相关参数解释 ↑2013年8月14日 ...
- libev和libuv的区别
libuv 和 libev ,两个名字相当相近的 I/O Library,最近有幸用两个 Library 都写了一些东西,下面就来说一说我本人对两者共同与不同点的主观表述. 高性能网络编程这个话题已经 ...
- libev与libuv的区别
参考: http://blog.csdn.net/w616589292/article/details/46475555 libuv 和 libev ,两个名字相当相近的 I/O Library,最近 ...
- [转帖]libev与libuv的区别
libev与libuv的区别 https://www.cnblogs.com/charlesblc/p/6341280.html 参考: http://blog.csdn.net/w616589292 ...
- libev事件库使用笔记
源码下载地址:http://dist.schmorp.de/libev/ libev是一个高性能的事件循环库,比libevent库的性能要好. 安装: tar -zxf libev-4.15.tar. ...
- python网络编程详解
最近在看<UNIX网络编程 卷1>和<FREEBSD操作系统设计与实现>这两本书,我重点关注了TCP协议相关的内容,结合自己后台开发的经验,写下这篇文章,一方面是为了帮助有需要 ...
- NodeJS服务器端平台实践记录
[2015 node.js learning notes]by lijun 01-note Nodejs是服务器端的javascript,是一种单线程.异步I/O.事件驱动型的javascript:其 ...
- C加加学习之路 1——开始
C++是一门古老而复杂的语言,绝不是一门可以速成的语言,学习它需要有意识的刻意练习和长时间的持续不断的磨练.而大多数人不太能耐得住寂寞,喜欢速成,所以像<21天学通C++>这种书就比较受欢 ...
随机推荐
- WS_EX_TOOLWINDOW 属性的陷阱
WS_EX_TOOLWINDOW,带有这个属性的窗口有以下特点: 1. 不在任务栏显示. 2. 不显示在Alt+Tab的切换列表中. 3. 在任务管理器的窗口管理Tab中不显示. 我们可能会出于某种目 ...
- 终于懂了:Delphi重定义消息结构随心所欲,只需要前4个字节是消息编号就行了(有了这个,就有了主动)
Delphi重定义消息结构随心所欲,只需要前4个字节是消息编号就行了,跟Windows消息虽然尽量保持一致,但其实相互没有特别大的关系.有了这个,就有了主动,带不带句柄完全看需要. 比如这个结构就带句 ...
- JAVA UTF-8字符转换为GBK
String t = "\u53d6"; try { String gbk=URLEncoder.encode(t,"GBK"); System.out.pri ...
- TCPDump:捕获并记录特定协议 / 端口
Q. 如何使用 Linux / UNIX 平台下的 TCPDump 工具捕获特定协议或端口比如 80 (http)?如何使用 TCPDump 将流记录下来,然后(根据记录)查找到问题所在? ...
- 双击GridView查看详情
效果如下: protected void gvEquData_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowTy ...
- linux-0.11抠代码-bootsect
//bootfun.s .global asm_message .global asm_memmove .global asm_readsector .global asm_checkLBA .cod ...
- HDU--杭电--3790--最短路径问题
最短路径问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- Qt 多线程 详细函数说明及其事例
转:http://www.cnblogs.com/hicjiajia/archive/2011/02/03/1948955.html Qt线程类 Qt 包含下面一些线程相关的类:QThread 提供了 ...
- eclipse插件maven的使用,web打包成WAR,tomcat下直接运行
1.首先下载maven 其下载地址为:http://maven.apache.org/download.html 下载apache-maven-3.0.3-bin.zip 环境变量配置为 变量 ...
- STL algorithm算法is_permutation(27)
is_permutation原型: std::is_permutation equality (1) template <class ForwardIterator1, class Forwar ...