io.Copy 関数を使用して、ソース Reader からターゲット Writer にデータをコピーします
Go 言語では、データ ストリームをある場所から別の場所にコピーする必要がある状況によく遭遇します。このプロセスを簡素化するために、Go 言語には非常に便利な関数 io.Copy が用意されています。
io.Copy 関数は次のように定義されています:
func Copy(dst Writer, src Reader) (int64 で書き込まれ、エラー エラー)
この関数は 2 つのパラメータをそれぞれ受け取ります. ターゲット Writer とソース Reader です。ソース Reader のデータを 1 つずつ読み取り、ソース Reader のすべてのデータがコピーされるまでターゲット Writer に書き込みます。この関数は、正常にコピーされたバイト数と発生した可能性のあるエラーを示す int64 型の値を返します。
具体的な使用例を見てみましょう。
package main
import (
"fmt" "io" "os"
)
func main() {
sourceFile, err := os.Open("source.txt") if err != nil { fmt.Println("打开源文件失败:", err) return } defer sourceFile.Close() destFile, err := os.Create("dest.txt") if err != nil { fmt.Println("创建目标文件失败:", err) return } defer destFile.Close() written, err := io.Copy(destFile, sourceFile) if err != nil { fmt.Println("复制文件失败:", err) return } fmt.Printf("成功复制了%d个字节的数据
", 書き込み済み)
}
上記のコードでは、最初に os.Open 関数でソース ファイルを開き、次に os.Create 関数でターゲット ファイルを作成し、ソース ファイルとターゲット ファイルを io に渡しました。 .Copy 関数はコピー操作を実行します。最後に、コピーに成功したバイト数を出力します。
読者は、ソース ファイルとターゲット ファイルのパスを置き換えるなど、必要に応じてコードを変更できます。
io.Copy 関数にはいくつかのバッファー操作があるため、大きなファイルをコピーするときにより多くのメモリを消費する可能性があることに注意してください。大きなファイルをコピーする必要がある場合は、カスタム バッファ サイズを設定するには、io.CopyBuffer 関数を使用することをお勧めします。
概要:
io.Copy 関数を使用すると、ある場所から別の場所にデータ ストリームを簡単にコピーできます。データのコピー作業を自分で処理して、コードをより簡潔かつ効率的にしてください。この記事のサンプル コードが読者の io.Copy 関数の理解と使用に役立つことを願っています。
以上がio.Copy 関数を使用して、ソース Reader からターゲット Writer にデータをコピーします。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。