허용하는 함수가있는 시나리오가 주어지면 t interface{}
. 이 t
조각 이라고 판단되면 해당 조각을 어떻게 range
덮어야합니까?
func main() {
data := []string{"one","two","three"}
test(data)
moredata := []int{1,2,3}
test(data)
}
func test(t interface{}) {
switch reflect.TypeOf(t).Kind() {
case reflect.Slice:
// how do I iterate here?
for _,value := range t {
fmt.Println(value)
}
}
}
Go Playground 예 : http://play.golang.org/p/DNldAlNShB
답변
그럼 난 사용 reflect.ValueOf
후는 슬라이스 인 경우는 호출 할 수 있습니다 Len()
및 Index()
얻을 수있는 값에 len
인덱스에 슬라이스와 요소를. 나는 당신이 이것을하기 위해 범위 작동을 사용할 수 없을 것이라고 생각합니다.
package main
import "fmt"
import "reflect"
func main() {
data := []string{"one","two","three"}
test(data)
moredata := []int{1,2,3}
test(moredata)
}
func test(t interface{}) {
switch reflect.TypeOf(t).Kind() {
case reflect.Slice:
s := reflect.ValueOf(t)
for i := 0; i < s.Len(); i++ {
fmt.Println(s.Index(i))
}
}
}
Go Playground 예 : http://play.golang.org/p/gQhCTiwPAq
답변
예상되는 유형을 알고 있으면 리플렉션을 사용할 필요가 없습니다. 다음 과 같이 유형 스위치를 사용할 수 있습니다 .
package main
import "fmt"
func main() {
loop([]string{"one", "two", "three"})
loop([]int{1, 2, 3})
}
func loop(t interface{}) {
switch t := t.(type) {
case []string:
for _, value := range t {
fmt.Println(value)
}
case []int:
for _, value := range t {
fmt.Println(value)
}
}
}
답변
interface {}가 동작하는 방식에는 한 가지 예외가 있습니다. @Jeremy Wall은 이미 포인터를 제공했습니다. 전달 된 데이터가 처음에 [] interface {}로 정의 된 경우.
package main
import (
"fmt"
)
type interfaceSliceType []interface{}
var interfaceAsSlice interfaceSliceType
func main() {
loop(append(interfaceAsSlice, 1, 2, 3))
loop(append(interfaceAsSlice, "1", "2", "3"))
// or
loop([]interface{}{[]string{"1"}, []string{"2"}, []string{"3"}})
fmt.Println("------------------")
// and of course one such slice can hold any type
loop(interfaceSliceType{"string", 999, map[int]string{3: "three"}})
}
func loop(slice []interface{}) {
for _, elem := range slice {
switch elemTyped := elem.(type) {
case int:
fmt.Println("int:", elemTyped)
case string:
fmt.Println("string:", elemTyped)
case []string:
fmt.Println("[]string:", elemTyped)
case interface{}:
fmt.Println("map:", elemTyped)
}
}
}
산출:
int: 1
int: 2
int: 3
string: 1
string: 2
string: 3
[]string: [1]
[]string: [2]
[]string: [3]
------------------
string: string
int: 999
map: map[3:three]