> 백엔드 개발 > Golang > Go에서 해시 맵용 복합 키를 어떻게 만들 수 있나요?

Go에서 해시 맵용 복합 키를 어떻게 만들 수 있나요?

Patricia Arquette
풀어 주다: 2024-11-09 15:36:02
원래의
344명이 탐색했습니다.

How can I create composite keys for hash maps in Go?

Go에서 해시 맵용 복합 키 생성

사전과 같은 빠른 데이터 액세스가 필수적인 해시 테이블 영역에서, 복합 키의 개념은 레코드의 고유성이 여러 값의 조합에 따라 달라질 때 발생합니다. 이는 데이터베이스에 사용되는 복합 기본 키와 유사하지만, 이 맥락에서 인메모리 해시 맵을 다루고 있다는 점에 유의하는 것이 중요합니다.

복합 키 정의

미리 계산된 pow(x, y) 값을 해시 테이블에 저장하는 시나리오를 생각해 보세요. 여기서 x와 y는 정수입니다. 문제는 이 조합을 나타내는 키를 생성하는 것입니다.

구조체를 키로 사용

다양하고 초보자에게 친숙한 접근 방식 중 하나는 복합 키. 이 경우 X와 Y라는 두 개의 정수 필드가 있는 Key 구조체를 만듭니다.

type Key struct {
    X, Y int
}
로그인 후 복사

이 구조체는 레코드를 고유하게 식별하는 데 필요한 x와 y 값의 조합을 효과적으로 캡처합니다.

키 구현

정의된 Key 구조체를 사용하여 이제 이 복합 키로 맵을 생성할 수 있습니다.

m := map[Key]int{}
로그인 후 복사

계산된 값으로 맵을 채울 수 있습니다. 복합 키를 사용하여 검색합니다.

m[Key{2, 2}] = 4 // pow(2, 2)
m[Key{2, 3}] = 8 // pow(2, 3)

fmt.Println("2^2 =", m[Key{2, 2}])
fmt.Println("2^3 =", m[Key{2, 3}])
로그인 후 복사

이렇게 하면 pow(2, 2) 및 pow(2, 3)에 대한 예상 값이 출력됩니다.

고려 사항

구조체를 키로 사용할 때 동등 비교가 올바르게 구현되었는지 확인하세요. 이는 비어 있지 않은 모든 필드가 비교 가능해야 함을 의미합니다. 또한 포인터는 메모리 주소만 비교하므로 키 유형으로 사용하지 마세요.

구조체 대신 배열을 복합 키로 사용할 수도 있지만 유연성이 떨어집니다.

결론 , 구조체는 Go에서 해시 맵에 대한 복합 키를 생성하는 강력한 메커니즘을 제공하여 여러 값을 기반으로 데이터를 효율적으로 검색할 수 있습니다. 이러한 기술을 활용하면 데이터의 구성과 접근성이 향상되어 작업과 해석이 더 쉬워집니다.

위 내용은 Go에서 해시 맵용 복합 키를 어떻게 만들 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿