将 JSON 解组到接口{}可以处理多种数据类型。然而,直接断言已解封的 interface{} 的类型会带来挑战。
在给定的场景中,interface{} 是从收到的消息中解封的。尝试在此 interface{} 上执行类型切换(如代码片段中所示)会产生意外结果,类型被声明为 map[string]interface{}。
要解决此问题,了解这一点很重要JSON 包解组到的默认类型,如其中所列文档:
自解组是在接口{}中执行的,结果类型将仅限于该集合。因此,该包不知道像 Something1 和 Something2 这样的自定义结构。
解决方案选项:
1。直接解组:
为了避免中间接口{}处理,可以将 JSON 数据直接解组为所需的结构类型。例如:
var job Something1 json.Unmarshal([]byte(msg), &job)
2。从通用接口转换:
如果需要使用通用接口{},可以从map[string]接口{}手动解包数据。这是一个示例:
var input interface{} json.Unmarshal([]byte(msg), &input) if smth1, ok := input.(map[string]interface{}); ok { job := Something1{ Thing: smth1["thing"].(string), OtherThing: smth1["other_thing"].(int64), } }
3.包装结构:
对于处理各种数据类型很常见的情况,具有自定义 UnmarshalJSON 方法的包装结构可以简化流程。此方法可以尝试将数据解组到不同的结构中并相应地设置数据字段。
以上是如何安全地将 JSON 解组到 Interface{} 并处理类型断言?的详细内容。更多信息请关注PHP中文网其他相关文章!