国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

啃論文俱樂部---JSON壓縮算法解讀

系統 OpenHarmony
cJSON壓縮算法的特點就是可以使用自動類型提取壓縮JSON數據格式的內容。它成功解決了一個非常重要的問題,就是我們上一小節提到的第三點,將不斷重復的鍵名舍去了。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

JSON壓縮算法解讀

接下來我們進入關于JSON壓縮算法的學習。

為什么需要壓縮JSON?

盡管JSON數據格式比XML效率要高,但是它仍然是web服務器和瀏覽器傳輸過程中比較低效的數據格式。為什么呢?首先,它將所有的內容都轉換為了文本,第二是轉換之后的文本過度使用引號,這樣會給每個字符串添加多兩個字節。第三,它本身沒有schema的標準格式,比如在一個消息中序列化多個對象的時候,即使每個對象的屬性的鍵名是重復且相同的,但是轉換后的文本數據還是會重復每一個鍵名。

JSON以前的時候有一個優勢,就是可以被Javascript引擎直接解析,但因為現在越來越重視安全性,JSON的這個優勢也逐漸消失了,但是因為它比XML效率以及性能都更高,所以許多傳統的C/S模式都是選擇JSON,比如web服務,當有龐大的數據量以及復雜數據結構需要從web瀏覽器中傳輸到服務器的時候,JSON壓縮就起到了非常大的作用,然而中間就會存在我們剛剛說的三點問題,我們也不能使用傳統的gzip壓縮算法,因為瀏覽器不知道服務器是否支持gzip解壓。

下面我們就來看看兩種常見的JSON壓縮算法,cJSON與HPack。

cJSON壓縮算法(cJSON Compression Algorithm)

cJSON壓縮算法的特點就是可以使用自動類型提取壓縮JSON數據格式的內容。它成功解決了一個非常重要的問題,就是我們上一小節提到的第三點,將不斷重復的鍵名舍去了,我們我們來看一個例子:

使用cJSON前的數據格式:

[
{ //表示一個坐標點
"x":100,
"y":100
},
{ //表示一個長方形
"x":100,
"y":100,
"width":200,
"height":150
},
{},//表示一個空對象
... //以下省略數以萬計的對象
]

上面未經壓縮的數據中,我們可以看到有非常多的空間被重復的鍵名所占據,比如“x”,“y”等等,當數據非常多的時候,這些看起來不起眼的重復鍵名會給傳輸效率帶來非常大的影響,其實解決思路也非常簡單,因為他們是重復的,那我們??只存儲一次??不就好了?下面我們來按照我們的思路看看cJSON處理過后的數據吧。

{
"templates":[
["x","y"], //type1
["x","y","width","height"] //type2
],
"value":[
{ //第一個對象:坐標點
"type":1,
"values":[
100,
100
]
},
{ //第二個對象:矩形
"type":2,
"values":[
100,
100,
200,
150
]
},
{
//第三個空對象
},
//以下省略數以萬計的對象......
]
}

從上面的數據中我們可以看到,我們格式化了數據,把鍵名存儲了起來,重復的就不存儲,然后值通過“type”索引來對應鍵名,這樣在數據量龐大的時候確實減少了不少空間,但是我們仔細看“templates”內的鍵名依舊有重復的字段存在。說明了我們還存在優化空間,優化完壓縮后效果如下:

{  "function": "cjson",
"templates": [
[0, "x", "y"],
[1, "width", "height"]
],
"values": [
[1, 100, 100 ], //第一個對象:坐標點
[2, 100, 100, 200, 150 ], //第二個對象:矩形
[] //第三個空對象
]
}

直接看壓縮后的代碼結構你可能不太能理解,那我們就來看看他的具體原理,為了解決“template”內鍵名重復的字段,這個算法采用了樹這個數據結構,每遇到一個要傳輸的對象,就按順序把鍵值存入樹的節點中(灰色的節點是被標記的結尾節點指針,表示該節點存儲的是某個對象最后一個屬性的鍵值),重復的就不存儲,這樣就解決了我們的問題,這個鍵值樹的變化過程如下:

【FFH】啃論文俱樂部---JSON壓縮算法解讀-開源基礎軟件社區

最后數據在匹配鍵值的時候就根據 “values” 中所標記的結尾節點指針找到對應鍵值數組,這樣就構成了cJSON的壓縮算法。

仔細的同學就會發現,如果一個對象中沒有"X"和"Y",只有“width”和“height”,或者鍵值節點順序是錯的,是不是會出問題?答案是對的,會出現無法匹配的鍵值的情況,所以這種方法只能在特定的場景下應用,存在一定局限性。

總體來說,cJSON在處理非常龐大的數據量的時候效果還是非常客觀的。

JSON.HPack壓縮算法(HPack Compression Algorithm)

JSON.HPack是一種無損、跨語言、注重性能的JSON數據壓縮算法,可以讓我們在使用post請求在客戶端發送數據到服務器的過程中相對普通JSON格式節省約70%的字符。

其原理本質上也是跟cJSON一樣將鍵值抽離開,舉個例子:

使用HPack算法前:

{   
"id" : 1,
"sex" : "Female",
"age" : 38,
"classOfWorker" : "Private",
"maritalStatus" : "Married-civilian spouse present",
"education" : "1st 2nd 3rd or 4th grade",
"race" : "White"
}

使用HPack算法后:

["id","sex","age","classOfWorker","mari talStatus","education","race"],
[1,"Female",38,"Private","Married-civilian spouse present","1st 2nd 3rd or 4th grade","White"]

可以看到相對于普通JSON以及cJSON少了很多字符,比如引號,各種括號等等,這種壓縮算法在數據量龐大的情況下效果也非常可觀。

HPack算法提供了幾個級別的壓縮(從0到4)。等級越高壓縮效率越高,每提升一個等級都有引入附加功能。0級壓縮通過從結構中分離鍵值來執行最基本的壓縮,并在索引0的元素上創建鍵名數組,下一個等級就可以通過假設存在重復條目來進一步減小JSON數據的大小。

性能分析

接下來我們直接用數據來看看這幾個壓縮算法的壓縮效率,我們分別用5組大小不同的JSON文件(50KB~1MB),每個JSON文件將使用servlet容器(tomcat)提供給瀏覽器,并分別用以下算法進行壓縮:

  • Original JSON size - 未作修改的JSON數據。
  • Minimized - 刪除空白和新行(最基本的js優化)。
  • Compresse cJSON - 使用CJSON壓縮算法進行JSON壓縮。
  • Compresse HPack - 使用JSON.HPack壓縮算法進行JSON壓縮。
  • Gzipped - 使用gzip和進行JSON壓縮。
  • Gzipped + Minimized - 使用gzip和刪除空白和新行(最基本的js優化)進行JSON壓縮。
  • Gzipped + Compresse cJSON - 使用gzip和CJSON壓縮算法進行JSON壓縮。
  • Gzipped + Compresse HPack - 使用gzip和JSON.HPack壓縮算法進行JSON壓縮。

下圖(TABLE I.RESULTES)是用以上各種方式處理完后的JSON數據大小(bytes),不同列表示不同的JSON數據集,不同行表示使用不同的壓縮方式。

【FFH】啃論文俱樂部---JSON壓縮算法解讀-開源基礎軟件社區

下面第一個圖表Y軸表示JSON數據大小(bytes):

【FFH】啃論文俱樂部---JSON壓縮算法解讀-開源基礎軟件社區

第二張圖Y軸是JSON數據大小的百分比(%),原始數據為100%:

【FFH】啃論文俱樂部---JSON壓縮算法解讀-開源基礎軟件社區

從上面的幾個圖表中我們可以直觀地看到,單獨使用cJSON可以把原始數據大小壓縮到45%左右,單獨使用HPack可以把原始數據大小壓縮到8%左右,可見整體上HPack是優于cJSON的。

然而我們可以看到當使用gzip和上面提到的兩個壓縮算法相結合進行JSON壓縮,效果才是最優的,基本可以達到1%~2%的壓縮率。

總的來說,HPack比cJSON效率更高,速度也更快,但是在使用壓縮算法進行傳輸的過程中,接收的一端需要進行相應的解壓縮操作,否則無法使用被壓縮過后的JSON數據,這一步也會存在一定的性能開銷,在我們選擇使用JSON壓縮的時候,也需要考慮到這一點。當可以使用gzip進行壓縮的時候,這種方法比其他壓縮算法的效率都高,當兩者同時結合起來,效果顯而易見。

好了,我們這一次完整地了解了JSON序列化的發展,規范,應用以及相關的壓縮算法,相信大家不僅對JSON壓縮算法有了更深的了解,也對JSON序列化這個技術領域有了深刻的認識。

文章相關附件可以點擊下面的原文鏈接前往下載:

https://ost.51cto.com/resource/2290。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??。


責任編輯:jianghua 來源: ??51CTO開源基礎軟件社區
相關推薦

2022-08-22 17:36:13

啃論文方法啃論文俱樂部

2022-06-15 15:56:22

壓縮算法神經網絡

2022-10-18 16:14:28

2022-04-07 15:03:07

Harmony計算機鴻蒙

2022-06-27 14:01:31

LZ4 分析數據密集型壓縮算法

2022-05-12 15:05:32

云計算數據壓縮

2022-06-08 16:29:45

無損壓縮方案分布式

2022-06-08 11:46:29

字符串鴻蒙

2022-05-13 22:44:35

物聯網算法鴻蒙

2022-06-15 16:06:29

LZ4 算法硬件加速

2022-06-15 15:44:21

無損數據壓縮鴻蒙

2022-04-20 20:37:58

鴻蒙操作系統

2022-09-30 13:57:15

JSON解析C語言

2022-05-13 23:03:25

大數據Big Data巨量資料

2022-02-24 16:32:26

OpenHarmon壓縮編碼鴻蒙

2022-09-07 15:08:58

操作系統鴻蒙

2022-09-16 15:01:37

操作系統技術鴻蒙

2022-09-13 16:10:15

鴻蒙操作系統

2022-09-06 15:46:52

speexdsp鴻蒙

2022-09-14 15:28:19

操作系統鴻蒙
點贊
收藏

51CTO技術棧公眾號

国产精品伦理在线| 亚洲福利视频二区| 国产伦精品一区二区三区四区视频| 超级碰碰不卡在线视频| 国产欧美日韩三级| 日本精品一区二区三区高清 久久 日本精品一区二区三区不卡无字幕 | 日韩免费高清| 久久久97精品| 美女精品导航| 欧美日韩国产精品专区| 国产日韩一区二区在线观看| 丝袜美腿成人在线| 91网站免费观看| 亚洲8888| 久久久久久国产精品| av日韩中文| 欧美日韩国产免费| 日本国产在线| 亚洲国产综合色| 激情综合网五月激情| 亚洲专区一区| 91久久精品国产91久久| 最新国产精品视频| 国内精品久久影院| 国产一区二区高清在线| 亚洲男人的天堂网站| 在线观看的网站你懂的| 欧美在线制服丝袜| 久久天堂电影| 色综合中文字幕| 婷婷综合影院| 亚洲精品视频免费看| 在线观看国产一级片| 久久奇米777| 国产偷人视频免费| 91在线小视频| 激情五月开心婷婷| 久久久欧美精品sm网站| 久久久精品在线视频| 91天堂素人约啪| 日本久久久精品视频| 91在线观看地址| 亚洲精品蜜桃久久久久久| 狠狠狠色丁香婷婷综合久久五月| 亚洲国产精品久久久久婷婷老年| 新狼窝色av性久久久久久| 欧美精品一区在线发布| 视频一区中文字幕| 亚洲一卡二卡三卡| 国产精品911| 免费 成 人 黄 色| 久久精品免费在线观看| 亚洲免费av一区二区三区| 国产女同互慰高潮91漫画| 丰满少妇在线观看| 一区二区三区四区激情| 天堂在线中文字幕| 在线精品视频免费播放| 国产福利视频在线| 国产午夜精品理论片a级探花| 亚洲精品成人图区| 欧美日韩国产二区| 国产一区二区三区日韩精品| 91久久久久久久| 久久国产主播| 人妻无码久久一区二区三区免费| 久久精品男人的天堂| 亚洲美女在线免费观看| 欧美日韩视频在线第一区| bl在线肉h视频大尺度| 久久精品国产视频| 欧美色女视频| 欧洲av一区| 91看片淫黄大片一级在线观看| 五月婷婷导航| 91成人免费在线| 18aaaa精品欧美大片h| 久久伊人精品一区二区三区| 国产一区二区三区四区二区| 久久av一区二区三区漫画| 国产精品99久久久久久久vr| 成人xxx免费视频播放| 91国内精品野花午夜精品 | 日韩视频一区在线| 亚洲日产av中文字幕| www.一区二区三区| 国产成人午夜片在线观看高清观看| 国模无码视频一区二区三区| 亚洲免费大片在线观看| 黄色在线观看网站| 日韩专区在线播放| 亚洲最大av| 国产精品久久久影院| 亚洲欧美综合色| 久久久123| 97香蕉久久夜色精品国产| 国产专区一区| 欧美黄网站在线观看| 欧洲精品一区二区三区在线观看| 欧美三区四区| 亚洲中国色老太| 99riav久久精品riav| 美女做暖暖视频免费在线观看全部网址91| 亚洲精品国产精品自产a区红杏吧| 青青久久av| 在线观看成人免费| 欧美性猛交xxxx| 国产精品久久免费视频| 国产精品一区在线观看| 亚洲国产成人在线| 97在线超碰| 亚洲free性xxxx护士白浆| 99精品视频在线播放观看| 日本中文字幕伦在线观看| 91精品国产色综合久久不卡98| 日本亚洲免费观看| 波多野结衣中文字幕在线| 中文字幕不卡在线视频极品| 亚洲视频福利| 国外亚洲成av人片在线观看| 中文字幕国产精品久久| 久久精品盗摄| 三级毛片在线免费看| 91国在线精品国内播放 | 国产成人av网址| 国产精品自拍视频| 国产一区视频在线观看免费| 亚洲少妇第一页| 亚洲欧美成人网| 99热免费精品| 在线播放中文字幕| 欧美激情一级精品国产| 国产69精品久久777的优势| 在线观看美女网站大全免费| 国产精品99久久久久久久久| 99re66热这里只有精品3直播 | **欧美大码日韩| 成人黄页网站视频| 亚洲不卡一卡2卡三卡4卡5卡精品| 欧美视频一区二区三区…| 人体久久天天| 日韩黄色短视频| 日韩av网址在线观看| 亚洲少妇在线| 成年人视频在线观看免费| 国产精品免费一区| 国产精品欧美一区喷水| 欧美91在线|欧美| av日韩在线看| 国产视频精品自拍| 久色婷婷小香蕉久久| 欧洲日本在线| 精品视频一区二区| 欧美日韩亚洲国产综合| 国产一区二区三区四区老人| 在线观看免费毛片| 亚洲mm色国产网站| 日韩欧美在线视频免费观看| 91精品国产乱码久久久久久| 视频国产一区二区三区| 国产日韩欧美影视| 一本久久综合亚洲鲁鲁五月天| 国产精品7m凸凹视频分类| 91热爆在线观看| 91最新在线免费观看| 日本久久电影网| 99精品免费| 国产网站在线| 水蜜桃色314在线观看| 久久五月天综合| 国产人久久人人人人爽| av毛片精品| 中国动漫在线观看完整版免费| 91久久久久久久一区二区| 欧美三级欧美一级| 日韩黄色免费电影| 日韩和的一区二在线| 人人爽人人av| 国产ts一区二区| 欧美性生活一区| 激情久久久久久久久久久久久久久久| 精品国产免费人成网站| 可以免费观看av毛片| 日韩av免费在线观看| 91黄色在线观看| 热久久国产精品| 国产在线一区不卡| 黄污网站在线观看| 欧美亚洲另类久久综合| 亚洲天堂免费在线| 中文字幕在线一区免费| 午夜性色一区二区三区免费视频| 日本不卡影院| 一本久道中文无码字幕av| 国产精品日日摸夜夜添夜夜av| 欧美日韩国产一级| 91欧美一区二区| 欧美精品一卡| 欧美系列精品| 国产一区二区影视|