Go에서 요소를 나열하는 함수 적용의 간결한 구현
목록의 각 구성원에 변환을 적용하고 결과를 저장하려는 경우 새 목록에서는 명시적인 루프에 의존하는 것이 일반적입니다. 그러나 Python에서는 목록 내포가 아래에 설명된 것처럼 간결한 대안을 제공합니다.
list = [1,2,3] str = ', '.join(multiply(x, 2) for x in list)
Go에서는 유사한 접근 방식을 사용하려면 더 장황한 루프 구조가 필요합니다.
list := []int{1,2,3} list2 := []int for _,x := range list { list2 := append(list2, multiply(x, 2)) } str := strings.Join(list2, ", ")
그러나 Go는 1.18에서는 지도 기능을 갖춘 우아한 솔루션을 소개합니다. 다음은 Map 구현 및 사용법입니다.
func Map[T, V any](ts []T, fn func(T) V) []V { result := make([]V, len(ts)) for i, t := range ts { result[i] = fn(t) } return result }
input := []int{4, 5, 3} outputInts := Map(input, func(item int) int { return item + 1 }) outputStrings := Map(input, func(item int) string { return fmt.Sprintf("Item:%d", item) })
이 간결한 구문은 목록 요소의 변환을 단순화하고 이러한 작업에 대해 명시적 루프에 비해 상당한 이점을 제공합니다.
위 내용은 Go의 맵 기능은 어떻게 목록 요소 변환을 간소화할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!