>백엔드 개발 >Golang >Go 배열에서 요소 멤버십을 효율적으로 확인하는 방법은 무엇입니까?

Go 배열에서 요소 멤버십을 효율적으로 확인하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-31 15:49:09779검색

How to Efficiently Check for Element Membership in Go Arrays?

Go에서 배열의 멤버십 확인

Go에서는 Python과 달리 Python의 "if x in"에 해당하는 내장 구문이 없습니다. "배열에 요소가 있는지 확인하는 데 사용됩니다.

Post Go 1.18 (권장 접근 방식)

Go 1.18부터 슬라이스를 사용할 수 있습니다. 슬라이스의 멤버십을 효율적으로 확인할 수 있는 기능이 포함되어 있습니다.

if slices.Contains(array, "x") {
    // Do something
}

Pre Go 1.18 (대체 방법)

이용하는 경우 이전 버전의 Go에는 두 가지 옵션이 있습니다.

  1. 반복 검색: 배열을 반복하고 각 요소를 대상 값 "x"와 비교합니다. 이 접근 방식은 대규모 배열에는 비효율적입니다.
func stringInSlice(a string, list []string) bool {
    for _, b := range list {
        if b == a {
            return true
        }
    }
    return false
}
  1. 맵 사용법: 키-값 쌍을 사용하여 배열을 맵(사전)으로 변환합니다. 목표 값이고 값은 부울입니다. 이 접근 방식은 배열 크기에 관계없이 일정한 조회 시간을 갖습니다.
visitedURL := map[string]bool{
    "http://www.google.com": true,
    "https://paypal.com": true,
}
if visitedURL["thisSite"] {
    fmt.Println("Already been here.")
}

데이터 수집의 크기와 특성에 따라 적절한 접근 방식을 선택해야 한다는 점을 기억하세요.

위 내용은 Go 배열에서 요소 멤버십을 효율적으로 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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