当前位置: 技术问答>linux和unix
sendfile()函数为什么效率高? 它的实现难道没有涉及普通I/O函数么
来源: 互联网 发布时间:2017-02-05
本文导语: 普通的I/O函数如read/write是要从内核内存拷贝内容到用户内存的。 为什么说sendfile()避免了这个? 我没有看过linux的源代码,不知道,是不是说这个函数的内部实现不是调用了用户态的read/write进行循环,而是直接调用...
普通的I/O函数如read/write是要从内核内存拷贝内容到用户内存的。
为什么说sendfile()避免了这个? 我没有看过linux的源代码,不知道,是不是说这个函数的内部实现不是调用了用户态的read/write进行循环,而是直接调用了linux内核层的东西?
大虾指点一下!
为什么说sendfile()避免了这个? 我没有看过linux的源代码,不知道,是不是说这个函数的内部实现不是调用了用户态的read/write进行循环,而是直接调用了linux内核层的东西?
大虾指点一下!
|
read copy_to_user
write copy_from_user
两次 copy
sendfile kernel space --> kernel space 直接一次
中间少一个交互。
用户空间相当于一个临时空间
write copy_from_user
两次 copy
sendfile kernel space --> kernel space 直接一次
中间少一个交互。
用户空间相当于一个临时空间
您可能感兴趣的文章:
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。