>백엔드 개발 >Golang >Go에서 바이트 슬라이스를 int64로 효율적으로 인코딩하려면 어떻게 해야 하나요?

Go에서 바이트 슬라이스를 int64로 효율적으로 인코딩하려면 어떻게 해야 하나요?

Susan Sarandon
Susan Sarandon원래의
2024-12-05 14:03:10637검색

How can I efficiently encode a byte slice into an int64 in Go?

Go에서 효율적인 바이트 슬라이스 인코딩

Go에서 관용적 접근 방식을 사용하여 어떻게 바이트 슬라이스를 int64로 인코딩할 수 있나요? 다음 코드 조각을 고려해보세요.

import "fmt"

func main() {
    var mySlice = []byte{244, 244, 244, 244, 244, 244, 244, 244}
    var data int64
    for i := 0; i < 8; i++ {
                data |= int64(mySlice[i] & byte(255)) << uint((8*8)-((i+1)*8))
    }
    fmt.Println(data)
}

이 코드가 작업을 수행하는 동안 동일한 결과를 얻을 수 있는 더 간결하고 우아한 방법이 있습니까?

관용적인 솔루션

바이트 슬라이스를 int64로 인코딩하는 보다 관용적인 방법은 다음과 같습니다. code:

func main() {
    var mySlice = []byte{244, 244, 244, 244, 244, 244, 244, 244}
    data := int64(0)
    for _, b := range mySlice {
        data = (data << 8) | int64(b)
    }
    fmt.Printf("%d\n", data)
}

이 솔루션에서는 범위 연산자를 활용하여 바이트 슬라이스의 요소를 반복하고 비트 왼쪽 시프트 연산자(<<)를 사용하여 값을 효율적으로 누적합니다. int64.

관용어의 장점 접근 방식

  • 단순성: 루프는 비트 조작과 복잡한 계산을 방지하므로 더 간단하고 읽기 쉽습니다.
  • 유지 관리성: 컬렉션을 반복하는 일반적인 패턴을 따르므로 향후 유지 관리 및 확장이 더 간단합니다. 값을 누적합니다.
  • 효율성: 단순함에도 불구하고 코드는 여전히 효율적이며 원래 접근 방식과 시간 및 공간 복잡성이 비슷합니다.

결론

원래 코드 조각이 특정 측면에서 더 명확할 수 있지만 비트 조작 작업의 경우 관용적 접근 방식이 더 간결하고 우아하며 유지 관리가 쉽습니다. 대부분의 경우 Go에서 바이트 슬라이스를 int64로 인코딩하는 데 관용적 솔루션이 선호됩니다.

위 내용은 Go에서 바이트 슬라이스를 int64로 효율적으로 인코딩하려면 어떻게 해야 하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.