Golang ファイルの読み取り操作: 大きなファイルをすばやく読み取るためのヒント
Golang ファイルの読み取り操作: 大きなファイルをすばやく読み取るためのヒント、特定のコード例が必要です
Golang プログラミングでは、ファイルの読み取りは非常に一般的な操作です。ただし、大きなファイルを読み取る必要がある場合は、通常、時間とリソースを消費する操作になります。したがって、大きなファイルを素早く読み取る方法は議論する価値のあるトピックです。この記事では、Golang の機能の使用方法と、大きなファイルをすばやく読み取るためのいくつかのテクニックを紹介し、具体的なコード例を示します。
- bufio を使用してファイルを読み取る
Golang で最も一般的に使用されるファイルの読み取りは、bufio パッケージによって提供されるバッファー読み取り操作を使用することです。 bufio は、Reader、Writer、Scanner の 3 つの構造を提供します。このうち Reader はバッファ読み出しに使用される構造体です。 Reader を使用してファイルを読み取る場合、バッファ サイズを設定し、読み取ったデータをバッファに入れることで、読み取り回数を大幅に減らすことができます。コードは次のように実装されます。
func ReadFileWithBufio(filePath string) ([]byte, error) { file, err := os.Open(filePath) if err != nil { return nil, err } defer file.Close() reader := bufio.NewReader(file) buffer := bytes.NewBuffer(make([]byte, 0)) for { line, isPrefix, err := reader.ReadLine() buffer.Write(line) if err != nil { if err == io.EOF { break } return nil, err } if !isPrefix { buffer.WriteString(" ") } } return buffer.Bytes(), nil }
上記のコードでは、bufio.Reader の ReadLine() メソッドを使用してファイルを読み取ります。一度に 1 行のデータを読み取り、後続のデータがあるかどうかを判断します。後続のデータがある場合は、引き続き後続のデータを読み取り、バッファに入れます。後続のデータがない場合は、読み取ったデータがバッファに入れられ、改行文字が追加されます。ファイルの読み込みが完了すると、バッファに保存されていたデータが返されます。
bufio パッケージを使用してファイルを読み取ることには、次の利点があります。
- バッファ サイズを設定することにより、ファイルの読み取り回数が大幅に削減され、読み取り効率が向上します。
- ファイルを 1 行ずつ読み取り、処理して、コードの可読性と保守性を向上させることができます。
- ioutil を使用してファイルを読み取る
Golang 標準ライブラリには、ファイルの読み取りに関連する操作が含まれる ioutil パッケージも提供されています。 ioutil パッケージの ReadFile() メソッドを使用すると、ファイル全体を一度に読み取ることができます。ファイル全体を一度に読み取るには比較的大きなメモリ空間が必要となるため、この方法は通常、ファイルのサイズが数 G を超えない場合に適しています。コードは次のように実装されます。
func ReadFileWithIOUtil(filePath string) ([]byte, error) { data, err := ioutil.ReadFile(filePath) if err != nil { return nil, err } return data, nil }
上記のコードでは、ioutil パッケージの ReadFile() メソッドを使用してファイル全体を読み取ります。ファイルの読み込みが完了すると、ファイルの内容が[]byte型で返されます。
ioutil パッケージを使用してファイルを読み取る利点は、コードがシンプルで、理解しやすく、使いやすいことです。欠点は、ファイル サイズが大きい場合、大量のメモリ領域を占有する必要があり、メモリ オーバーフローが発生しやすいことです。したがって、この方法は小さなファイルを読み取る場合にのみ推奨されます。
- bufio と goroutine を使用してチャンクで読み取る
読み取るファイルが非常に大きい場合、またはメモリ容量を超える場合は、Goroutine テクノロジを使用して読み取ります。おそらくチャンク ファイルが最良のオプションです。ファイル全体を複数のブロックに分割し、各ブロックからの読み取り用のゴルーチンを有効にすることができます。たとえば、次のコードは 1 GB のファイルを 100 のチャンクに分割し、各チャンクのサイズは 10 MB です。
const fileChunk = 10 * (1 << 20) // 10 MB func ReadFileWithMultiReader(filePath string) ([]byte, error) { file, err := os.Open(filePath) if err != nil { return nil, err } defer file.Close() fileInfo, _ := file.Stat() fileSize := fileInfo.Size() if fileSize < fileChunk { return ioutil.ReadFile(filePath) } buffer := bytes.NewBuffer(make([]byte, 0)) chunkSize := int(math.Ceil(float64(fileSize) / float64(100))) for i := 0; i < 100; i++ { offset := int64(i * chunkSize) readSize := int(math.Min(float64(chunkSize), float64(fileSize-int64(i*chunkSize)))) buf := make([]byte, readSize) file.ReadAt(buf, offset) go func(b []byte) { buffer.Write(b) }(buf) } time.Sleep(time.Millisecond * 100) return buffer.Bytes(), nil }
上記のコードでは、まず読み込むファイルのサイズを計算します。ファイルサイズが10MB未満の場合は、ioutilを使用してファイル全体を一度に読み込みます。それ以外の場合は、ファイルが100個に分割されます。ブロック。各ブロックのサイズは fileSize/100 です。次に、100 個のゴルーチンのループを作成し、ファイルを 1 つずつチャンクで読み取り、読み取ったデータをバッファーに書き込みます。最後に、 time.Sleep() メソッドを使用してすべてのゴルーチンの実行を完了し、バッファに保存されたデータを返します。
この方法を使用してファイルを読み取る利点は次のとおりです。
- メモリ使用量が少なく、非常に大きなファイルを読み取ることができます。
- このコードは同時実行のサポートに非常に適しており、複数のデータ ブロックを同時に処理できます。
概要
この記事の導入部を通じて、さまざまなファイル サイズや読み取り方法に応じて、さまざまなテクニックを使用してファイル読み取り効率を向上できることがわかりました。小さいファイルの場合は、ioutil パッケージを使用して 1 回限りの読み取りを行うことができます。大きなファイルの場合は、バッファ読み取りには bufio パッケージを使用し、チャンク読み取りには goroutine を使用できます。実際のプロジェクトでは、プログラムのパフォーマンスと信頼性を向上させるために、実際の状況に応じて最適な読み取り方法を選択する必要があります。
以上がGolang ファイルの読み取り操作: 大きなファイルをすばやく読み取るためのヒントの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Go ではファイルを安全に読み書きすることが重要です。ガイドラインには以下が含まれます。 ファイル権限の確認 遅延を使用してファイルを閉じる ファイル パスの検証 コンテキスト タイムアウトの使用 これらのガイドラインに従うことで、データのセキュリティとアプリケーションの堅牢性が確保されます。

Go データベース接続の接続プーリングを構成するにはどうすればよいですか?データベース接続を作成するには、database/sql パッケージの DB タイプを使用します。同時接続の最大数を制御するには、MaxOpenConns を設定します。アイドル状態の接続の最大数を設定するには、ConnMaxLifetime を設定します。

Go フレームワークは、その高いパフォーマンスと同時実行性の利点で際立っていますが、比較的新しい、開発者エコシステムが小さい、一部の機能が欠けているなどの欠点もあります。さらに、急速な変化と学習曲線はフレームワークごとに異なる場合があります。 Gin フレームワークは、効率的なルーティング、組み込みの JSON サポート、強力なエラー処理機能により、RESTful API を構築するための一般的な選択肢です。

GoLang フレームワークと Go フレームワークの違いは、内部アーキテクチャと外部機能に反映されています。 GoLang フレームワークは Go 標準ライブラリに基づいてその機能を拡張していますが、Go フレームワークは特定の目的を達成するための独立したライブラリで構成されています。 GoLang フレームワークはより柔軟であり、Go フレームワークは使いやすいです。 GoLang フレームワークはパフォーマンスの点でわずかに優れており、Go フレームワークはよりスケーラブルです。ケース: gin-gonic (Go フレームワーク) は REST API の構築に使用され、Echo (GoLang フレームワーク) は Web アプリケーションの構築に使用されます。

JSON データは、gjson ライブラリまたは json.Unmarshal 関数を使用して MySQL データベースに保存できます。 gjson ライブラリは、JSON フィールドを解析するための便利なメソッドを提供します。json.Unmarshal 関数には、JSON データをアンマーシャリングするためのターゲット型ポインターが必要です。どちらの方法でも、SQL ステートメントを準備し、データをデータベースに永続化するために挿入操作を実行する必要があります。

ベスト プラクティス: 明確に定義されたエラー タイプ (エラー パッケージ) を使用してカスタム エラーを作成する 詳細を提供する エラーを適切にログに記録する エラーを正しく伝播し、非表示または抑制しないようにする コンテキストを追加するために必要に応じてエラーをラップする

Go フレームワークで一般的なセキュリティ問題に対処する方法 Web 開発で Go フレームワークが広く採用されているため、そのセキュリティを確保することが重要です。以下は、一般的なセキュリティ問題を解決するための実践的なガイドであり、サンプル コードも含まれています。 1. SQL インジェクション SQL インジェクション攻撃を防ぐには、プリペアド ステートメントまたはパラメータ化されたクエリを使用します。例: constquery="SELECT*FROMusersWHEREusername=?"stmt,err:=db.Prepare(query)iferr!=nil{//Handleerror}err=stmt.QueryR

FindStringSubmatch 関数は、正規表現に一致する最初の部分文字列を検索します。この関数は、最初の要素が一致した文字列全体で、後続の要素が個々の部分文字列である、一致する部分文字列を含むスライスを返します。コード例: regexp.FindStringSubmatch(text,pattern) は、一致する部分文字列のスライスを返します。実際のケース: 電子メール アドレスのドメイン名を照合するために使用できます。たとえば、email:="user@example.com", pattern:=@([^\s]+)$ を使用してドメイン名を照合します。 [1]。
