Go의 바이트 버퍼에서 정수 값을 효율적으로 압축 해제하는 방법
바이너리 데이터 스트림에서 다양한 필드를 추출하는 것은 일반적인 작업일 수 있습니다. 프로그램 작성. Go에서 bytes 패키지는 바이트 버퍼를 읽고 조작하는 방법을 제공합니다.
질문:
어떻게 바이트 버퍼에서 여러 정수 필드를 읽고 압축을 풀 수 있나요? 명시적인 필드 오프셋을 유지하고 중복 버퍼를 최소화하는 동시에 보다 효율적인 방식 할당?
답변:
두 가지 접근 방식이 있습니다.
1. bytes.Buffer.Next()를 사용하여 원하지 않는 바이트 건너뛰기:
각 필드에 대해 새 버퍼를 만드는 대신 bytes.Buffer.Next() 메서드를 사용하여 원하지 않는 바이트를 건너뛸 수 있습니다. 이 접근 방식은 메모리 할당을 방지하고 읽기 프로세스를 간소화합니다.
p := bytes.NewBuffer(buf) // ... p.Next(12) // Skip [8:20) binary.Read(p, binary.LittleEndian, &fs.sb.firstDataBlock) // ...
2. 구조체를 사용하여 헤더를 직접 읽기:
이 방법을 사용하면 반복적인 버퍼 조작이 필요하지 않습니다. 헤더 레이아웃을 나타내는 구조체를 정의하고 Binary.Read()를 사용하여 버퍼에서 직접 읽을 수 있습니다.
type Head struct { // Field definitions } var header Head err := binary.Read(file, binary.LittleEndian, &header)
두 접근 방식 모두 Go의 바이트 버퍼에서 정수 값의 압축을 풀 수 있는 효율적이고 안정적인 방법을 제공합니다. 지정된 요구 사항을 충족합니다.
위 내용은 Go 바이트 버퍼에서 여러 정수 필드를 효율적으로 압축 해제하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!