>백엔드 개발 >Golang >Go Maps에 대한 사용자 정의 키 동일성을 어떻게 구현할 수 있나요?

Go Maps에 대한 사용자 정의 키 동일성을 어떻게 구현할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2025-01-02 21:31:39943검색

How Can I Implement Custom Key Equality for Go Maps?

Go 맵의 사용자 정의 키 동일성

Go에서 맵을 생성할 때 구현하는 한 모든 유형을 키로 사용할 수 있습니다. 비교할 수 있는 인터페이스. 기본적으로 Go는 키 비교를 위해 내장된 항등 연산자(==)를 사용합니다. 그러나 고유한 동등 기준을 정의하려는 경우가 있을 수 있습니다.

다음 사용자 정의 키 유형을 고려하세요.

type Key struct {
    a *int
}

Key의 두 인스턴스를 비교하려면 자신만의 Equal을 사용하려고 합니다. 함수:

func Equal(x Key, y Key) bool {
    return *x.a == *y.a
}

해결 방법

안타깝게도 Go에서는 맵 키에 대한 사용자 정의 해싱 또는 동등 함수를 지정할 수 없습니다. 대신 다음 해결 방법을 사용할 수 있습니다.

  1. 키 속성 파생: Key 구조체를 키로 직접 사용하는 대신 속성(예: 정수 또는 문자열)을 파생합니다. 이는 키의 ID 역할을 합니다. 의미상 동일한 키에 대해서만 충돌이 발생하는지 확인하세요.
  2. 해시 함수 구현: 파생 속성을 계산하고 이를 정수로 반환하는(해싱용) 키에 대한 메서드를 만듭니다.
func (k *Key) HashKey() int {
    return *(*k).a
}

예시 사용법

위의 예를 사용하면 맵은 다음과 같습니다.

k1, k2 := Key{intPtr(1)}, Key{intPtr(2)}
m := map[int]string{}
m[k1.HashKey()] = "one"
m[k2.HashKey()] = "two"

주의사항

이 접근 방식은 불변성에 의존한다는 점을 기억하세요. 파생된 키 속성의 Key 구조체의 필드가 변경되면 키의 ID가 변경되고 예상대로 작동하지 않습니다.

위 내용은 Go Maps에 대한 사용자 정의 키 동일성을 어떻게 구현할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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