据我所知,类型断言只能在接口中使用,基本上检查确定的类型是否实现了接口。
我有一些奇怪的情况:
func binder(value interface{}) {
// Does not work
valueInt, ok := value.(int)
// Works
valueInt, ok := value.(float64)
// Does not work
coordinates, ok := value.([]int)
// Does not work
coordinates, ok := value.([]float64)
}
基本上,我的
value
是一个空界面,我是从json.Unmarshall
获得的。场景1
当我传递一个简单的整数时,它不起作用,但如果我检查它是否是浮点数,它就会起作用…
场景2
当我传递一个int或float数组时不起作用!正如您在调试时所看到的,我正在接收一个数组,但由于某些原因断言不起作用。
最佳答案:
json.Unmarshal
var x map[string]interface{}
json.Unmarshal([]byte(`{"foo":123}`), &x) // { "foo": float64(123) }
VS:
var x map[string]int64
json.Unmarshal([]byte(`{"foo":123}`), &x) // { "foo": int64(123) }
默认情况下,所有json数组都会反编组到
[]interface{}
,因为成员可以是任何类型,包括混合类型。如果您想要特定的类型,同样,您必须是特定的:var x interface{}
json.Unmarshal([]byte(`[1,2,3]`), &x) // []interface{}{float64(1), float64(2), float64(3)}
VS:
var x []int64
json.Unmarshal([]byte(`[1,2,3]`), &x) // []int64{1,2,3}