Go では、bufio はデータの読み書きに便利な方法を提供しますバッファリングされた方法で。ただし、キャリッジ リターン ライン フィード (CRLF) 区切り文字で区切られたメッセージを処理する場合、bufio.ReadLine のデフォルトの動作では不十分な場合があります。この記事では、bufio を使用して CRLF 区切り文字を含むメッセージを読み取る別のアプローチについて説明します。
CRLF 区切り文字を含むメッセージを読み取るには、bufio.Scanner をカスタム スキャナーと組み合わせて利用できます。スキャン機能。 SplitFunc メソッドを使用すると、各メッセージの境界を決定するカスタム関数を定義できます。
<code class="go">func ScanCRLF(data []byte, atEOF bool) (advance int, token []byte, err error) { if atEOF && len(data) == 0 { return 0, nil, nil } if i := bytes.Index(data, []byte{'\r', '\n'}); i >= 0 { // We have a full newline-terminated line. return i + 2, dropCR(data[0:i]), nil } // If we're at EOF, we have a final, non-terminated line. Return it. if atEOF { return len(data), dropCR(data), nil } // Request more data. return 0, nil, nil }</code>
カスタム スキャン関数では、CRLF 区切り文字を検索し、それに応じてメッセージを返します。 DropCR 関数は、末尾の r がメッセージから確実に削除されるようにします。
これで、リーダーをカスタム スキャナーでラップできます。
<code class="go">scanner := bufio.NewScanner(this.reader) scanner.Split(ScanCRLF)</code>
Scan を呼び出すことで、リーダー内のメッセージ:
<code class="go">for scanner.Scan() { fmt.Printf("%s\n", scanner.Text()) }</code>
代替アプローチは、メッセージ ヘッダーで指定されている特定のバイト数を読み取ることです。ただし、この方法は矛盾が発生しやすく、予想されるバイト数が正しくない場合、またはリーダー バッファーに追加のデータがある場合に、予期しない動作が発生する可能性があります。
このアプローチを使用するには、最初にヘッダー行を読み取ることができます。予想されるバイト数を取得するには:
<code class="go">res, err := this.reader.ReadLine('\n')</code>
次に、予想されるバイト数で限定されたリーダーを作成できます:
<code class="go">nr_of_bytes := // read_number_of_butes_somehow(this.reader) limitedReader := io.LimitReader(this.reader, int64(nr_of_bytes))</code>
最後に、メッセージ本文を読み取ることができます。制限されたリーダー:
<code class="go">buf := make([]byte, nr_of_bytes) limitedReader.Read(buf)</code>
ただし、このアプローチには制限があるため、一般に CRLF 区切り文字を使用したメッセージベースのアプローチに依存することをお勧めします。
以上がBufi を使用して Go で CRLF 区切りのメッセージを読み取る方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。