Go 言語ドキュメントの io.CopyN 関数を深く理解し、限られたバイト数でファイル コピーを実装する
Go 言語の io パッケージ入力出力ストリーム関数とメソッドを処理するための多くの関数を提供します。非常に便利な関数の 1 つは io.CopyN で、限られたバイト数でファイルをコピーできます。この記事では、この関数を深く理解し、具体的なコード例を示します。
まず、io.CopyN 関数の基本的な定義を理解しましょう。その定義は次のとおりです。
func CopyN(dst Writer, src Reader, n int64) (written int64, err error)
この関数の機能は、ソース Reader からターゲット Writer にデータをコピーし、最大 n バイトまでコピーすることです。コピーされるバイト数は n バイトを超えません。ソース リーダーのデータが n バイト未満の場合、コピーはソース リーダーの最後で停止します。
io.CopyN 関数を使用してファイルをコピーするには、まずソース ファイルとターゲット ファイルを開く必要があります。 os.Open 関数を使用してソース ファイルを開き、os.Create 関数を使用してターゲット ファイルを作成できます。以下は具体的なコード例です:
package main import ( "io" "log" "os" ) func main() { srcFile, err := os.Open("source.txt") if err != nil { log.Fatal(err) } defer srcFile.Close() dstFile, err := os.Create("destination.txt") if err != nil { log.Fatal(err) } defer dstFile.Close() written, err := io.CopyN(dstFile, srcFile, 1024) // 限定复制1KB字节 if err != nil { log.Fatal(err) } log.Printf("Copied %d bytes.", written) }
上記のコードでは、最初に os.Open 関数を使用してsource.txt という名前のソース ファイルを開き、os.Create 関数を使用して destination.txt という名前のファイルを作成しました。関数、対象ファイル。次に、io.CopyN 関数を呼び出して、ソース ファイル内のデータをターゲット ファイルに最大 1024 バイト (つまり 1KB) コピーします。コピーが完了すると、コピーされたバイト数が出力されます。
defer ステートメントを使用して、プログラムが終了する前に開いているファイルが確実に閉じられるようにすることに注意してください。これは、リソース リークを避けるために一般的に使用されるファイル処理パターンです。
上記のコード例では、最大コピーを 1KB バイトに制限しています。より多くのバイトまたはより少ないバイトをコピーしたい場合は、io.CopyN 関数に渡される 3 番目のパラメーターを変更するだけです。
要約すると、io.CopyN 関数は、ファイル コピー プロセス中にコピーされるバイト数を制限でき、非常に実用的です。 Go 言語ドキュメントでの io.CopyN 関数の深い理解と、具体的なコード例を使用したデモンストレーションを通じて、読者がこの関数を明確に理解し、実際の開発に柔軟に適用できることを願っています。
以上がGo 言語ドキュメントの io.CopyN 関数を深く理解し、限られたバイト数でファイルをコピーするの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。