一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Golang - golang json性能分析詳解

golang json性能分析詳解

2020-05-14 09:58hatlonely Golang

json格式可以算我們日常最常用的序列化格式之一了,Go語言作為一個由Google開發,號稱互聯網的C語言的語言,自然也對JSON格式支持很好。下面這篇文章主要給大家詳細分析介紹了golang json性能的相關資料,需要的朋友可以參考下。

前言

眾所周知Json 作為一種重要的數據格式,具有良好的可讀性以及自描述性,廣泛地應用在各種數據傳輸場景中。Go 語言里面原生支持了這種數據格式的序列化以及反序列化,內部使用反射機制實現,性能有點差,在高度依賴 json 解析的應用里,往往會成為性能瓶頸,好在已有很多第三方庫幫我們解決了這個問題,但是這么多庫,對于像我這種有選擇困難癥的人來說,到底要怎么選擇呢,下面就給大家來一一分析一下

ffjson

?
1
go get -u github.com/pquerna/ffjson

原生的庫性能比較差的主要原因是使用了很多反射的機制,為了解決這個問題,ffjson 通過預編譯生成代碼,類型的判斷在預編譯階段已經確定,避免了在運行時的反射

但也因此在編譯前需要多一個步驟,需要先生成 ffjson 代碼,生成代碼只需要執行 ffjson <file.go> 就可以了,其中 file.go 是一個包含 json 結構體定義的 go 文件。注意這里 ffjson 是這個庫提供的一個代碼生成工具,直接執行上面的 go get 會把這個工具安裝在 $GOPATH/bin 目錄下,把 $GOPATH/bin 加到 $PATH 環境變量里面,可以全局訪問

另外,如果有些結構,不想讓 ffjson 生成代碼,可以通過增加注釋的方式

?
1
2
3
4
5
6
7
8
// ffjson: skip
type Foo struct {
 Bar string
}
// ffjson: nodecoder
type Foo struct {
 Bar string
}

easyjson

?
1
go get -u github.com/mailru/easyjson/...

easyjson 的思想和 ffjson 是一致的,都是增加一個預編譯的過程,預先生成對應結構的序列化反序列化代碼,除此之外,easyjson 還放棄了一些原生庫里面支持的一些不必要的特性,比如:key 類型聲明,key 大小寫不敏感等等,以達到更高的性能

生成代碼執行 easyjson -all <file.go> 即可,如果不指定 -all 參數,只會對帶有 //easyjson:json 的結構生成代碼

?
1
2
3
4
//easyjson:json
type A struct {
 Bar string
}

jsoniter

?
1
go get -u github.com/json-iterator/go

這是一個很神奇的庫,滴滴開發的,不像 easyjson 和 ffjson 都使用了預編譯,而且 100% 兼容原生庫,但是性能超級好,也不知道怎么實現的,如果有人知道的話,可以告訴我一下嗎?

2018-1-28日更新,來自官方(@taowen)的回復:

沒啥神奇的。就是預先緩存了對應struct的decoder實例而已。然后unsafe.Pointer省掉了一些interface{}的開銷。還有一些文本解析上的優化

使用上面,你只要把所有的

?
1
import "encoding/json"

替換成

?
1
2
import "github.com/json-iterator/go"
var json = jsoniter.ConfigCompatibleWithStandardLibrary

就可以了,其它都不需要動

codec-json

?
1
go get -u github.com/ugorji/go/codec

這個庫里面其實包含很多內容,json 只是其中的一個功能,比較老,使用起來比較麻煩,性能也不是很好

jsonparser

?
1
go get -u github.com/buger/jsonparser

嚴格來說,這個庫不屬于 json 序列化的庫,只是提供了一些 json 解析的接口,使用的時候需要自己去設置結構里面的值,事實上,每次調用都需要重新解析 json 對象,性能并不是很好

就像名字暗示的那樣,這個庫只是一個解析庫,并沒有序列化的接口

性能測試

對上面這些 json 庫,作了一些性能測試,測試代碼在:https://github.com/hatlonely/hellogolang/blob/master/internal/json/json_benchmark_test.go,下面是在我的 Macbook 上測試的結果(實際結果和庫的版本以及機器環境有關,建議自己再測試一遍):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
BenchmarkMarshalStdJson-4     1000000   1097 ns/op
BenchmarkMarshalJsonIterator-4    2000000   781 ns/op
BenchmarkMarshalFfjson-4      2000000   941 ns/op
BenchmarkMarshalEasyjson-4     3000000   513 ns/op
BenchmarkMarshalCodecJson-4     1000000   1074 ns/op
BenchmarkMarshalCodecJsonWithBufio-4   1000000   2161 ns/op
BenchmarkUnMarshalStdJson-4     500000   2512 ns/op
BenchmarkUnMarshalJsonIterator-4    2000000   591 ns/op
BenchmarkUnMarshalFfjson-4     1000000   1127 ns/op
BenchmarkUnMarshalEasyjson-4     2000000   608 ns/op
BenchmarkUnMarshalCodecJson-4     20000  122694 ns/op
BenchmarkUnMarshalCodecJsonWithBufio-4  500000   3417 ns/op
BenchmarkUnMarshalJsonparser-4    2000000   877 ns/op
golang_json_performance

golang json性能分析詳解

從上面的結果可以看出來:

  • easyjson 無論是序列化還是反序列化都是最優的,序列化提升了1倍,反序列化提升了3倍
  • jsoniter 性能也很好,接近于easyjson,關鍵是沒有預編譯過程,100%兼容原生庫
  • ffjson 的序列化提升并不明顯,反序列化提升了1倍
  • codecjson 和原生庫相比,差不太多,甚至更差
  • jsonparser 不太適合這樣的場景,性能提升并不明顯,而且沒有反序列化

所以綜合考慮,建議大家使用 jsoniter,如果追求極致的性能,考慮 easyjson

參考鏈接

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:http://hatlonely.github.io/2018/01/28/golang-json-性能分析/

延伸 · 閱讀

精彩推薦
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細介紹,從例子說起,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網11352020-05-21
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

    這篇文章主要介紹了Golang中Bit數組的實現方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

    這篇文章主要介紹了Golang通脈之數據類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數名等等,Go語言中標識符允許由...

    4272021-11-24
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
主站蜘蛛池模板: 果冻传媒在线免费观看 | 色操网 | 国产在线精品亚洲第一区香蕉 | 欧洲老妇人70 | 99视频网址 | 三级理论在线播放大全 | 欧美一区二区三区在线观看不卡 | 国产成人影院在线观看 | oneday高清在线观看 | 成人国产一区二区 | 日韩二三区 | 亚洲视频免| 久久精品亚洲精品国产欧美 | 国产一区二区视频在线 | www.亚洲天堂 | 国产精品久久现线拍久青草 | 99精品全国免费7观看视频 | 成人福利在线观看 | 51国产午夜精品免费视频 | 好大好硬好长好爽a网站 | 思久久| 午夜宅男在线观看 | 精品视频一区二区观看 | 男人j进女屁股视频在线观看 | 波多野结衣在线观看视频 | a∨在线观看 | 二次元美女内裤凹陷太深 | 无人在线视频高清免费观看动漫 | 精品一区二区三区在线播放 | 免费高清视频在线观看 | 506070老熟肥妇bbwxx视频 500第一精品 | 国产一卡二卡3卡4卡四卡在线 | 色婷婷在线视频 | 日本高清在线精品一区二区三区 | 天堂网在线网站成人午夜网站 | 欧美视频一区二区三区四区 | 亚洲国产精品第一区二区三区 | 欧美日韩一区二区综合在线视频 | 乳女教师欲乱动漫无修版动画3d | 精品在线观看一区 | 成人高清视频在线观看 |