色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

JSON壓縮算法解讀

共熵服務中心 ? 來源:未知 ? 2022-11-23 19:10 ? 次閱讀

646e29d6-6b1e-11ed-8abf-dac502259ad0.png

文章轉發自51CTO 開源基礎軟件社區 OpenHarmony成長計劃啃論文俱樂部【FFH】啃論文俱樂部---JSON壓縮算法解讀

1.關于作者

大家好!我是來自深圳技術大學FSR Lab(編者注:Falcon Swarm Robotics Lab獵鷹集群機器人控制實驗室的縮寫)的同學,標題FFH就是FSRlab For Harmony!并且我也正在參加OpenHarmony成長計劃從論文到開源提交研究,以后我們也會陸續在這個社區記錄學習心得和體會。

在OpenHarmony成長計劃啃論文俱樂部里,FFH小組同學們與華為、軟通動力、潤和軟件、拓維信息、深開鴻等公司一起,學習和研究序列化相關技術…

2. 為什么需要壓縮JSON?

盡管JSON數據格式比XML效率要高,但是它仍然是web服務器和瀏覽器傳輸過程中比較低效的數據格式。為什么呢?

  • 首先,它將所有的內容都轉換為了文本。

  • 第二是轉換之后的文本過度使用引號,這樣會給每個字符串添加多兩個字節。

  • 第三,它本身沒有schema的標準格式,比如在一個消息中序列化多個對象的時候,即使每個對象的屬性的鍵名是重復且相同的,但是轉換后的文本數據還是會重復每一個鍵名。

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

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

3. cJSON壓縮算法

cJSON壓縮算法(cJSON Compression Algorithm)的特點就是可以使用自動類型提取壓縮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”內鍵名重復的字段,這個算法采用了樹這個數據結構,每遇到一個要傳輸的對象,就按順序把鍵值存入樹的節點中(灰色的節點是被標記的結尾節點指針,表示該節點存儲的是某個對象最后一個屬性的鍵值),重復的就不存儲,這樣就解決了我們的問題,這個鍵值樹的變化過程如下:

65312ac6-6b1e-11ed-8abf-dac502259ad0.png

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

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

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

4.JSON.HPack壓縮算法

JSON.HPack壓縮算法(HPack Compression Algorithm)是一種無損、跨語言、注重性能的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-civilianspousepresent","1st2nd3rdor4thgrade","White"]

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

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

5.性能分析

接下來我們直接用數據來看看這幾個壓縮算法的壓縮效率,我們分別用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數據集,不同行表示使用不同的壓縮方式。

65581424-6b1e-11ed-8abf-dac502259ad0.png

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

6582fcd4-6b1e-11ed-8abf-dac502259ad0.png

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

65bb7320-6b1e-11ed-8abf-dac502259ad0.png

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

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

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

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

6.參考文獻

JSON Compression Algorithmshttp://repository.utm.md/bitstream/handle/5014/6418/ICMCS_2011_1_pg_244_247.pdf?sequence=1

<本文完>

寫在最后

OpenHarmony 成長計劃—“啃論文俱樂部”(以下簡稱“啃論文俱樂部”)是在 2022年 1 月 11 日的一次日常活動中誕生的。截至 3 月 31 日,啃論文俱樂部已有 87 名師生和企業導師參與,目前共有十二個技術方向并行探索,每個方向都有專業的技術老師帶領同學們通過啃綜述論文制定技術地圖,按“降龍十八掌”的學習方法編排技術開發內容,并通過專業推廣培養高校開發者成為軟件技術學術級人才。

啃論文俱樂部的宗旨是希望同學們在開源活動中得到軟件技術能力提升、得到技術寫作能力提升、得到講解技術能力提升。大學一年級新生〇門檻參與,已有俱樂部來自多所高校的大一同學寫出高居榜首的技術文章。

如今,搜索“啃論文”,人們不禁想到、而且看到的都是我們——OpenHarmony 成長計劃—“啃論文俱樂部”的產出。

65d7c52a-6b1e-11ed-8abf-dac502259ad0.jpg

66146b92-6b1e-11ed-8abf-dac502259ad0.jpg

662b13ec-6b1e-11ed-8abf-dac502259ad0.jpg

OpenHarmony開源與開發者成長計劃—“啃論文俱樂部”學習資料合集

1)入門資料:啃論文可以有怎樣的體驗

https://docs.qq.com/slide/DY0RXWElBTVlHaXhi?u=4e311e072cbf4f93968e09c44294987d

2)操作辦法:怎么從啃論文到開源提交以及深度技術文章輸出https://docs.qq.com/slide/DY05kbGtsYVFmcUhU

3)企業/學校/老師/學生為什么要參與 & 啃論文俱樂部的運營辦法https://docs.qq.com/slide/DY2JkS2ZEb2FWckhq

4)往期啃論文俱樂部同學分享會精彩回顧:

同學分享會No1.成長計劃啃論文分享會紀要(2022/02/18)https://docs.qq.com/doc/DY2RZZmVNU2hTQlFY

同學分享會No.2 成長計劃啃論文分享會紀要(2022/03/11)https://docs.qq.com/doc/DUkJ5c2NRd2FRZkhF

同學們分享會No.3 成長計劃啃論文分享會紀要(2022/03/25)

https://docs.qq.com/doc/DUm5pUEF3ck1VcG92?u=4e311e072cbf4f93968e09c44294987d

現在,你是不是也熱血沸騰,摩拳擦掌地準備加入這個俱樂部呢?當然歡迎啦!啃論文俱樂部向任何對開源技術感興趣的大學生開發者敞開大門。

66710b54-6b1e-11ed-8abf-dac502259ad0.png

掃碼添加 OpenHarmony 高校小助手,加入“啃論文俱樂部”微信群

后續,我們會在服務中心公眾號陸續分享一些 OpenHarmony 開源與開發者成長計劃—“啃論文俱樂部”學習心得體會和總結資料。記得呼朋引伴來看哦。

6688276c-6b1e-11ed-8abf-dac502259ad0.gif

669befa4-6b1e-11ed-8abf-dac502259ad0.png

66d12a0c-6b1e-11ed-8abf-dac502259ad0.png

6700d540-6b1e-11ed-8abf-dac502259ad0.png

6786f7c4-6b1e-11ed-8abf-dac502259ad0.png

67c90f56-6b1e-11ed-8abf-dac502259ad0.png

67f68972-6b1e-11ed-8abf-dac502259ad0.png

6814e372-6b1e-11ed-8abf-dac502259ad0.png

6853c2f4-6b1e-11ed-8abf-dac502259ad0.png

68f83c8a-6b1e-11ed-8abf-dac502259ad0.png

691b1836-6b1e-11ed-8abf-dac502259ad0.png

6949b696-6b1e-11ed-8abf-dac502259ad0.png

69d3694a-6b1e-11ed-8abf-dac502259ad0.png

6a6bb498-6b1e-11ed-8abf-dac502259ad0.png

6a8efd18-6b1e-11ed-8abf-dac502259ad0.png

6aa52340-6b1e-11ed-8abf-dac502259ad0.png

6acf0e1c-6b1e-11ed-8abf-dac502259ad0.png

6b2ab64a-6b1e-11ed-8abf-dac502259ad0.png

6b47f3cc-6b1e-11ed-8abf-dac502259ad0.png

6b691b4c-6b1e-11ed-8abf-dac502259ad0.png

6b98fb3c-6b1e-11ed-8abf-dac502259ad0.png

6bb21158-6b1e-11ed-8abf-dac502259ad0.png

6bd4d6ca-6b1e-11ed-8abf-dac502259ad0.png

6bf73ef4-6b1e-11ed-8abf-dac502259ad0.png

6c138550-6b1e-11ed-8abf-dac502259ad0.png

6c5d1daa-6b1e-11ed-8abf-dac502259ad0.png

6c76cfb6-6b1e-11ed-8abf-dac502259ad0.png

6d10d5ca-6b1e-11ed-8abf-dac502259ad0.png


原文標題:JSON壓縮算法解讀

文章出處:【微信公眾號:開源技術服務中心】歡迎添加關注!文章轉載請注明出處。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 開源技術
    +關注

    關注

    0

    文章

    389

    瀏覽量

    7963
  • OpenHarmony
    +關注

    關注

    25

    文章

    3728

    瀏覽量

    16405

原文標題:JSON壓縮算法解讀

文章出處:【微信號:開源技術服務中心,微信公眾號:共熵服務中心】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    EE-257:面向Blackfin處理器的引導壓縮/解壓縮算法

    電子發燒友網站提供《EE-257:面向Blackfin處理器的引導壓縮/解壓縮算法.pdf》資料免費下載
    發表于 01-07 13:56 ?0次下載
    EE-257:面向Blackfin處理器的引導<b class='flag-5'>壓縮</b>/解<b class='flag-5'>壓縮</b><b class='flag-5'>算法</b>

    think-cell——使用JSON數據實現自動化(一)

    您可以使用 JSON 中的數據來復制最初作為模板創建的圖表,并為其提供新的數據表。您可以控制使用特定模板構建新演示文稿的順序。模板也可以多次使用。 PowerPoint 模板和 JSON 數據都可以
    的頭像 發表于 01-02 13:37 ?72次閱讀
    think-cell——使用<b class='flag-5'>JSON</b>數據實現自動化(一)

    【「從算法到電路—數字芯片算法的電路實現」閱讀體驗】+內容簡介

    內容簡介這是一本深入解讀基礎算法及其電路設計,以打通算法研發到數字IC設計的實現屏障,以及指導芯片設計工程師從底層掌握復雜電路設計與優化方法為目標的專業技術書。任何芯片(如WiFi芯片、5G芯片
    發表于 11-21 17:14

    【BearPi-Pico H3863星閃開發板體驗連載】LZO壓縮算法移植

    壓縮算法使用 一、概述 壓縮算法是一類用于減小數據大小的計算方法,它們在數據存儲和傳輸領域扮演著重要角色。壓縮
    發表于 11-10 21:45

    壓縮算法的類型和應用

    壓縮算法是一種通過減少數據量來節省存儲空間或傳輸數據的技術。壓縮算法可以分為兩種類型:有損壓縮和無損壓縮
    的頭像 發表于 10-21 13:50 ?293次閱讀

    Huffman壓縮算法概述和詳細流程

    Huffman壓縮算法是一種基于字符出現頻率的編碼算法,通過構建Huffman樹,將出現頻率高的字符用短編碼表示,出現頻率低的字符用長編碼表示,從而實現對數據的壓縮
    的頭像 發表于 10-21 13:48 ?300次閱讀

    名單公布!【書籍評測活動NO.46】從算法到電路 | 數字芯片算法的電路實現

    :elecfans123)領取書籍進行評測,如在5個工作日內未聯系,視為放棄本次試用評測資格! 《從算法到電路——數字芯片算法的電路實現》 是一本深入解讀基礎算法及其電路設計,以打通
    發表于 10-09 13:43

    使用qboot時選擇了壓縮率更高的zip算法,但是發現編譯報錯,為什么?

    在使用qboot時選擇了壓縮率更高的zip算法,但是發現編譯報錯,如下圖:
    發表于 09-26 07:22

    JSON協議是什么,物聯網中的RTU中如何使用JSON協議和服務器交互

    一 概述 1.1 什么是 JSON JSON是JavaScript Object Notation的簡稱,中文含義為“JavaScript 對象表示法”,它是一種數據交換的文本格式,而不是一種編程
    的頭像 發表于 09-25 16:14 ?910次閱讀
    <b class='flag-5'>JSON</b>協議是什么,物聯網中的RTU中如何使用<b class='flag-5'>JSON</b>協議和服務器交互

    【RTC程序設計:實時音視頻權威指南】音視頻的編解碼壓縮技術

    音視頻所載有的信息在通過傳輸的時候就需要壓縮編碼。 其中,文本壓縮是指通過使用各種算法和技術,將文本數據表示為更緊湊的形式,以減少存儲空間。 霍夫曼編碼是一種無損壓縮
    發表于 04-28 21:04

    FPGA壓縮算法有哪些

    在圖像壓縮算法中可以采用哈夫曼編碼的方式對編碼冗余的信息進行壓縮,可以采用預測的方式來減少像素間冗余,可以采用量化的方式完成心理視覺冗余信息的去除
    的頭像 發表于 04-15 11:48 ?673次閱讀
    FPGA<b class='flag-5'>壓縮</b><b class='flag-5'>算法</b>有哪些

    Python壓縮和解壓縮實現代碼分享

    壓縮和解壓縮是日常常用的操作,不管是windows上圖形界面的操作,還是linux上用命令來進行壓縮壓縮,總的而言都還是比較方便的。
    的頭像 發表于 04-11 11:28 ?1077次閱讀

    基于門控線性網絡(GLN)的高壓縮比無損醫學圖像壓縮算法

    實現基于門控線性網絡(GLN)的高壓縮比無損醫學圖像壓縮算法,以提高醫學圖像存儲和分發系統的效率。與“傳統”的基于上下文的數據壓縮算法相比,
    的頭像 發表于 04-08 10:29 ?684次閱讀
    基于門控線性網絡(GLN)的高<b class='flag-5'>壓縮</b>比無損醫學圖像<b class='flag-5'>壓縮</b><b class='flag-5'>算法</b>

    壓縮機的類型和區別

    壓縮機的類型和區別? 壓縮機是一種用于提高氣體壓縮和輸送能力的機械設備。根據不同的工作原理和應用需求,壓縮機可分為多種類型,包括離心壓縮機、
    的頭像 發表于 02-01 14:36 ?3546次閱讀

    ?PLC從HTTP服務端獲取JSON文件,解析數據到寄存器

    智能網關IGT-DSER集成了多種PLC協議,方便實現各種PLC與HTTP服務端之間通訊。通過網關的參數配置軟件綁定JSON文件的字段與PLC寄存器地址,配置URL,即可采用POST命令,將JSON
    發表于 01-24 09:47
    主站蜘蛛池模板: 日本粉嫩学生毛绒绒| yy8090韩国理伦片在线| 麻豆天美国产一区在线播放| oldgrand欧洲老妇人| 亚洲一区免费在线观看| 日本人吃奶玩奶虐乳| 久久久无码精品亚洲A片软件| 高H短篇辣肉纯肉| 2020国产成人精品免费视频| 羞羞漫画在线播放| 青娱乐极品视觉盛宴av| 久久黄视频| 国产精品免费一区二区三区视频| 99热久久这里只有精品视频| 一边捏奶头一边啪高潮会怎么样| 天天拍拍国产在线视频| 内射少妇36P九色| 久久久国产精品免费A片3D| 国产精品美女WWW爽爽爽视频| NANANA在线观看高清影院| 中文字幕中文字幕永久免费| 亚洲成在人线视频| 午夜福利不卡片在线播放免费| 青草国产在线视频免费| 免费成人高清在线视频| 久久女婷五月综合色啪| 黄色天堂在线| 国偷自产视频一区二区99| 国产精品嫩草免费视频| 国产99精品在线观看| 成人免费一区二区无码视频| AV天堂AV亚洲啪啪久久无码| 4388成人| 45分钟做受片免费观看| 又长又大又粗又硬3p免费视频| 亚洲精品动漫免费二区| 亚洲精品久久久午夜福利电影网| 亚洲haose在线观看| 亚洲AV午夜精品麻豆AV| 亚洲精品无码AAAAAA片| 亚洲日本香蕉视频观看视频|