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 중국어 웹사이트의 기타 관련 기사를 참조하세요!