根据我的理解,类型断言只能在接口中使用,并且基本上检查确定的类型是否实现接口。
我有一些奇怪的场景:
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数组或浮点数时不起作用!正如您在调试时所看到的,我正在接收一个数组但由于某种原因,断言不起作用。
答案 0 :(得分:5)
你的问题不清楚,但似乎归结为以下几点:
默认情况下,json.Unmarshal
将所有数字解组为float64,因为JSON中的所有数字都是浮点数。如果您需要其他类型,则需要在目标类型中使用特定类型。例子:
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}