在Go中复制文件最流行的3种方法
本文将向您展示如何在go编程语言。尽管go中有三种以上的复制文件的方法,但本文将介绍三种最常见的方法:这三种方法各有利弊,我们只需要在应用中选择最合适的即可,不必盲目追求性能。
使用io.copy()从go库调用函数;一次性读取输入文件并将其写入另一个文件;并使用缓冲区以小块的形式复制文件。
方法1:使用io.copy()
该实用程序的第一个版本将使用io.copy()标准go库的功能。实现中可以找到实用程序的逻辑。copy()职能如下:
除了测试要复制的文件是否存在外(os.stat(src)),并且是一个常规文件(sourcefilestat.mode().isregular())这样您就可以打开它阅读,所有的工作都是由io.copy(destination, source)声明。这,这个,那,那个io.copy()函数返回复制的字节数和复制过程中发生的第一条错误消息。在go中,如果没有错误消息,则错误变量的值将为nil.
您可以了解更多关于io.copy()在io封装文件页。
执行cp1.go将生成下一种输出:
$ run cp1 please provide two command line arguments $ run cp1 filecptxt tmpfilecpcopy copied bytes $ diff filecptxt tmpfilecpcopy
这种技术尽可能简单,但不给开发人员带来灵活性,这并不总是一件坏事。但是,有时开发人员需要或希望决定如何读取文件。
方法2:使用ioutil.writefile()和ioutil.readfile()
复制文件的第二种方法是使用ioutil.readfile()和ioutil.writefile()职能。第一个函数将整个文件的内容读入字节片,第二个函数将字节片的内容写入文件中。
实用程序的逻辑可以在以下go代码中找到:
除了这两个if块,它们是工作方式的一部分,您可以看到程序的功能在ioutil.readfile()和ioutil.writefile()陈述。
执行cp2.go将生成下一种输出:
$ run cp2 please provide two command line arguments $ run cp2 filecptxt tmpcopyfilecp $ diff filecptxt tmpcopyfilecp
请注意,尽管此技术将复制一个文件,但是当您想要复制大型文件时,它可能并不有效,因为ioutil.readfile()也将是巨大的。
方法3:使用os.read()和os.write()
在go中复制文件的第三种方法是使用cp3.go将在本节中开发的实用程序。它接受三个参数:输入文件的文件名、输出文件的文件名和缓冲区的大小。
最重要的部分cp3.go驻留在以下for循环,可以在copy() function:
这种技术使用os.read()用于将输入文件的一小部分读入名为buf和os.write()将缓冲区的内容写入文件。当读取错误或到达文件末尾时,复制过程停止(io.eof).
执行cp3.go将生成下一种输出:
$ run cp3 usage cp3 source destination buffersize $ run cp3 filecptxt tmpbuf10 copying filecptxt to tmpbuf10 $ run cp3 filecptxt tmpbuf20 copying filecptxt to tmpbuf20
如您所见,缓冲区的大小极大地影响了cp3.go.
做一些基准
本文的最后一部分将尝试比较这三个程序以及cp3.go对于不同的缓冲区大小,请使用time(1)命令行实用程序。
下面的输出显示了cp1.go, cp2.go,和cp3.go复制500 mb文件时:
输出结果表明,这三个实用程序的性能非常相似,这意味着标准go库的功能非常聪明和优化。
现在,让我们测试缓冲区大小如何影响cp3.go。执行cp3.go如果缓冲区大小为10、20和1,000字节,以便在相当快的计算机上复制500mb文件,生成的输出显示,缓冲区越大,cp3.go实用程序,这或多或少是预期的。此外,使用小于20个字节的缓冲区大小复制大文件是一个非常缓慢的过程,应该避免。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
上一篇: Spring4.0 WebSocket
下一篇: 你才是贱货