有没有办法使用 Go 下载大文件,将内容直接存储到文件中,而不是在将其写入文件之前将其全部存储在内存中?由于文件太大,在将其写入文件之前将其全部存储在内存中会耗尽所有内存。
我假设您的意思是通过 http 下载(为简洁起见省略了错误检查):
import ("net/http"; "io"; "os") ... out, err := os.Create("output.txt") defer out.Close() ... resp, err := http.Get("http://example.com/") defer resp.Body.Close() ... n, err := io.Copy(out, resp.Body)
http.Response 的 Body 是一个 Reader,因此您可以使用任何带有 Reader 的函数,例如一次读取一个块而不是一次读取全部。在这种特定情况下,io.Copy()为您做一些繁琐的工作。
io.Copy()