本文主要是介绍使用splice实现零拷贝复制文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
splice是linux2.6内核中新增的零拷贝数据发送函数,主要用于将数据发送到管道 或 从管道中接收数据。于splice类似的零拷贝发送函数还有sendfile,不同的是sendfile是将数据通过socket发到对端。所谓零拷贝是指(与传统的read/write模式相比),在数据发送的过程中,不需要在用户态为数据申请buffer,也就是不会产生用户态、内核态之间的数据拷贝(moves data between two file descriptors without copying between kernel address space and user addressspace)。比如,使用经典的read/write方式复制文件的流程为:1. buf = malloc(len) \\首先申请一块长度为len的内存
2. read(fd1, buf, len) \\将第一个文件fd1中len长度的数据读入buf
3. write(fd2, buf, len) \\将buf中的数据写入文件fd2中
在非direct io的场景下,会导致文件的数据会在内核态的page cache与用户态的buf之间发生两次拷贝(读过程中一次,写过程中一次)
splice系统调用的参数为:
这篇关于使用splice实现零拷贝复制文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!