互連網二十多年,已到十字路口。區塊鏈出現前的互連網被稱為古典互連網,而應用區塊鏈技術的互連網才進入了後互連網時代。作為一項新興的技術,區塊鏈無疑正處於風口浪尖之上,其發展前景於普通福士而言也終將是利好。但目前由於區塊鏈技術處於發展早期階段,存在技術成熟度等級、落地應用情境有限等問題,兄弟連教育建議使用者在選擇專業Go語言+區塊鏈培訓機構前應進行仔細考量與辨別。
今天遇到個介面需要處理一個json的map類型的數組,開始想法是用simple—json裡的Array讀取數組,然後遍曆數組取出每個map,然後讀取對應的值,在進行後續操作,貌似很簡單的工作,卻遇到了一個陷阱。
Json格式類似下邊:
{"code":0
,"request_id": xxxx
,"code_msg":""
,"body":[{
"device_id": "xxxx"
,"device_hid": "xxxx"
}]
, "count":0}
很快按上述想法寫好了帶碼,但是以外發生了,編譯不過,看一看代碼邏輯沒有問題,問題出在哪裡呢?
原來是interface{} Array方法返回的是一個interface{}類型的,我們都在golang裡interface是一個萬能的接受者可以儲存任意類型的參數,但是卻忽略了一點,它是不可以想當然的當任意類型來用,在使用之前一定要對interface類型進行判斷。我開始就忽略了這點,想當然的使用interface變數造成了錯誤。
下面寫了個小例子
package main
import (
"encoding/json"
"fmt"
"github.com/bitly/go-simplejson"
)
func main() {
//拼湊json body為map數組
var rbody []map[string]interface{}
t := make(map[string]interface{})
t["device_id"] = "dddddd"
t["device_hid"] = "ddddddd"
rbody = append(rbody, t)
t1 := make(map[string]interface{})
t1["device_id"] = "aaaaa"
t1["device_hid"] = "aaaaa"
rbody = append(rbody, t1)
cnnJson := make(map[string]interface{})
cnnJson["code"] = 0
cnnJson["request_id"] = 123
cnnJson["code_msg"] = ""
cnnJson["body"] = rbody
cnnJson["page"] = 0
cnnJson["page_size"] = 0
b, _ := json.Marshal(cnnJson)
cnnn := string(b)
fmt.Println("cnnn:%s", cnnn)
cn_json, _ := simplejson.NewJson([]byte(cnnn))
cn_body, _ := cn_json.Get("body").Array()
for _, di := range cn_body {
//就在這裡對di進行類型判斷
newdi, _ := di.(map[string]interface{})
device_id := newdi["device_id"]
device_hid := newdi["device_hid"]
fmt.Println(device_hid, device_id)
}
}
高能預警,兄弟連教育區塊鏈直播課程8月持續火爆來襲!
原價1188元的12節區塊鏈進階課程,現僅需1元!
還可免費領取《Go語言基礎實戰項目開發》與《Go語言進階實戰項目開發》教材兩本!!限時限量!!先到先得!!
http://www.ydma.cn/open/course/24
關注兄弟連區塊鏈技術公眾號領取更多技術乾貨哦!!!