女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內(nèi)不再提示

一個可應用于HarmonyOS的高效IO庫

HarmonyOS開發(fā)者 ? 來源:HarmonyOS開發(fā)者 ? 作者:HarmonyOS開發(fā)者 ? 2022-06-08 09:22 ? 次閱讀
前不久,三方組件庫上新了一批JS/eTS組件,其中就包括okio組件。okio是一個可應用于HarmonyOS的高效IO庫,它依托于系統(tǒng)能力,提供字符串的編解碼轉換能力,基礎數(shù)據(jù)類型的讀寫能力以及對文件讀寫的支持。本期將為大家介紹okio的工作原理及使用方法。

一、okio的產(chǎn)生背景

IO,即輸入輸出(Input/Output)。絕大多數(shù)應用都需要與外部進行數(shù)據(jù)交互,這就會涉及IO。系統(tǒng)提供了IO能力,在使用系統(tǒng)IO時,通常需要一個中間緩沖區(qū)來保存讀取到的數(shù)據(jù)。數(shù)據(jù)先從輸入流緩沖區(qū)復制到中間緩沖區(qū),再從中間緩沖區(qū)復制到輸出流緩沖區(qū)。中間多次拷貝,降低了IO效率,同時增加了系統(tǒng)消耗。為了滿足開發(fā)者對IO的更高要求,三方組件庫推出IO處理利器——okio(JS版本)。okio使用Segment作為數(shù)據(jù)存儲容器,通過提供Segment移動、共享、合并和分割的能力,讓數(shù)據(jù)讀寫變得非常靈活,也減少了數(shù)據(jù)復制,提升了IO效率。此外,okio還通過SegmentPool對Segment進行回收和復用,減少大量創(chuàng)建Segment帶來的系統(tǒng)消耗。下面就帶大家深入了解JS版本的okio的工作原理,探索它是如何提升IO效率的~

二、兩個基本概念

在深入解析okio的工作原理之前,我們先來了解兩個基本概念:Segment和SegmentPool。

1. Segment

okio將數(shù)據(jù)分割成一塊塊的片段存放在Segment里面。Segment是一個數(shù)據(jù)存儲的真正類,內(nèi)部維護著一個大小為8192字節(jié)的字節(jié)數(shù)組用于存儲數(shù)據(jù)。Segment最小可共享、可寫入的數(shù)據(jù)大小為1024字節(jié)。Segment使用pos、limit、shared、owner、prev、next來分別記錄讀寫位置、是否可寫入、是否能共享、數(shù)據(jù)擁有者、前置節(jié)點和后置節(jié)點信息。Segment對外提供sharedCopy、unsharedCopy、split、push、pop、compact、writeTo等接口用于操作數(shù)據(jù)。

Segment同時擁有前置節(jié)點和后置節(jié)點,構成一個雙向鏈表。讀取數(shù)據(jù)的時候,從雙向鏈表的頭部開始讀取;而寫入數(shù)據(jù)的時候,從雙向鏈表的尾部寫入數(shù)據(jù)。

2. SegmentPool為了管理Segment,okio維護了一個Segment對象池(即SegmentPool),對廢棄的Segment回收、復用和內(nèi)存共享,從而減少內(nèi)存的申請和GC(garbage collection,垃圾收集)的頻率,使性能得到優(yōu)化。SegmentPool是一個由最多8個Segment組成的單鏈表。一個Segment的最大大小是8192字節(jié)(即8KB),所以SegmentPool的最大大小是64KB。

三、okio的工作原理

okio組件最重要的功能就是“讀”和“寫”。下面我們就從讀寫開始,了解okio的工作原理。

1. 讀寫數(shù)據(jù)okio讀寫數(shù)據(jù)的過程中,遵循大塊數(shù)據(jù)移動、小塊數(shù)據(jù)復制的原則。okio從輸入流讀取數(shù)據(jù)到輸入流緩沖區(qū)時,會先找到雙向鏈表尾部的Segment節(jié)點,如果此節(jié)點的剩余容量足夠,則直接將讀取到的數(shù)據(jù)存入到此節(jié)點。如果此節(jié)點的剩余容量不足,則從SegmentPool里面取一個Segment鏈接到雙向鏈表的尾部,然后將數(shù)據(jù)存入這個新節(jié)點。okio從輸入流緩沖區(qū)讀取數(shù)據(jù),再寫入數(shù)據(jù)到輸出流緩沖區(qū)。這個過程比較復雜,有以下幾種情況:

(1) 從輸入流緩沖區(qū)獲取到Segment,如果數(shù)據(jù)是滿的(字節(jié)數(shù)組data長度為8092字節(jié)),那么直接修改此Segment的prev和next信息,將其添加到輸出流緩沖區(qū)的雙向鏈表的尾部,省去一次數(shù)據(jù)復制過程。

bc533964-e6c8-11ec-ba43-dac502259ad0.png

圖1大塊數(shù)據(jù)移動 (2) 從輸入流緩沖區(qū)獲取到Segment(假設為Segment1),如果數(shù)據(jù)不是滿的,可以通過pos和limit信息來確定segment1的可讀數(shù)據(jù),再和輸出流緩沖區(qū)的雙向鏈表的尾部節(jié)點(假設為Segment2)的剩余容量進行對比: 如果Segment1的可讀數(shù)據(jù)比Segment2的剩余容量小,則把Segment1的數(shù)據(jù)復制到Segment2,然后回收Segment1到SegmentPool。 如果Segment1的可讀數(shù)據(jù)比Segment2的剩余容量大,那么直接修改Segment1的prev和next信息,將其添加到Segment2的后面。

(3) 從輸入流緩沖區(qū)獲取到Segment(假設為Segment3),如果只需要傳遞部分數(shù)據(jù)(比如總數(shù)據(jù)為4096字節(jié),只傳遞1024字節(jié)),okio會通過split接口將Segment3拆分成含3072字節(jié)數(shù)據(jù)的Segment3-1和含1024字節(jié)數(shù)據(jù)的Segment3-2,然后按照(2)的邏輯將Segment3-2的數(shù)據(jù)寫入輸出流緩沖區(qū)。

bc708a3c-e6c8-11ec-ba43-dac502259ad0.png

圖2 Segment拆分

拆分Segment的時候,可以通過參數(shù)指定拆分后的第一個Segment含有的未讀字節(jié)數(shù)(byteCount)。拆分后,第一個Segment包含的數(shù)據(jù)范圍是[pos,pos+byteCount),第二個Segment包含的數(shù)據(jù)范圍是[pos+byteCount,limit)。拆分Segment時也遵循大塊數(shù)據(jù)移動、小塊數(shù)據(jù)復制的原則。當byteCount大于1024時,使用共享的Segment,否則復制數(shù)據(jù)。(注:文件、流、socket相關的IO優(yōu)化需要系統(tǒng)支持,待后續(xù)版本優(yōu)化提供。)2. Segment的回收與復用接下來,我們再來看看SegmentPool是如何回收和復用Segment的。

每次okio想要使用Segment就從SegmentPool中獲取,使用完畢后又會放回到SegmentPool中等待復用,核心方法為take()和recycle()。

(1) take()方法

take()方法負責從對象池單鏈表的頭部獲取可以使用的Segment。如果獲取不到,說明單鏈表是空的,此時新創(chuàng)建一個Segment給緩沖區(qū)使用。如果能獲取到,則取出單鏈表的頭部節(jié)點,再將下一個節(jié)點置為單鏈表的頭部節(jié)點,并將取出來的Segment的next置空,同時更新對象池大小。

(2) recycle()方法recycle()方法負責回收緩沖區(qū)里面使用完畢的Segment。回收開始時,首先更新對象池大小,然后把回收對象Segment添加到單鏈表頭部,接著重置Segment的pos和limit為0。注意,以下情況不會回收Segment:
  • 當前Segment的prev和next不為空

  • 當前Segment是共享的

  • 對象池已經(jīng)有8個Segment了

3. 字符串處理除了Segment和SegmentPool外,okio還封裝了ByteString類來進行字符串處理。ByteString提供Base64編解碼、utf-8編碼、十六進制編解碼、大小寫轉換、內(nèi)容比較等豐富的API,可以很方便地處理字符串。在進行字符串處理時,由于ByteString同時持有原始字符串和對應的字節(jié)數(shù)組,可以直接使用字節(jié)數(shù)組里面的數(shù)據(jù)進行操作,不需要先將字符串轉換為字節(jié)數(shù)組。特別是在頻繁轉換編碼的場景下,通過這種以空間換時間的方式,可以避免字符串與字節(jié)數(shù)組的多次轉換,減少了時間和系統(tǒng)性能消耗。

四、okio的使用及示例

1. 前置配置步驟一:在entry 的package.json文件中添加以下依賴項。
"dependencies": {    "okio": "^1.0.0"  }
步驟二:配置倉庫鏡像地址。
npm config set @ohos:registry=https://repo.harmonyos.com/npm/
步驟三:DevEco Studio的Terminal里面輸入以下命令下載源代碼。
cd entrynpm install @ohos/okio

步驟四:文件的頭部引入okio庫。
 import okio from '@ohos/okio';
步驟五:在config.json文件中申請存儲權限。
   "reqPermissions": [      {        "name": "ohos.permission.WRITE_USER_STORAGE", //寫入用戶存儲的權限        "reason": "Storage",        "usedScene": {          "when": "always",          "ability": [            "com.example.okioapplication.MainAbility"          ]        }      },      {        "name": "ohos.permission.READ_USER_STORAGE", //讀取用戶存儲的權限        "reason": "Storage",        "usedScene": {          "when": "always",          "ability": [            "com.example.okioapplication.MainAbility"          ]        }      },      {        "name": "ohos.permission.WRITE_EXTERNAL_MEDIA_MEMORY", //寫入外部存儲的權限        "reason": "Storage",        "usedScene": {          "when": "always",          "ability": [            "com.example.okioapplication.MainAbility"          ]        }      }    ]    }

2. 代碼實現(xiàn)執(zhí)行完上面的配置操作后,就可以進入代碼編寫階段了。開發(fā)者可以使用okio提供的豐富的API接口來實現(xiàn)功能。下面為大家展示四個實現(xiàn)示例,供大家參考學習。

示例1:文件寫入和讀取

bc977156-e6c8-11ec-ba43-dac502259ad0.gif

本示例通過sink將內(nèi)容寫入文件,通過source從文件讀取內(nèi)容。代碼如下:
//通過sink將內(nèi)容寫入文件var sink = new okio.Sink(this.fileUri);sink.write(this.Value,false); //通過source從文件讀取內(nèi)容var source = new okio.Source(this.fileUri);source.read().then(function (data) { context.readValue = data;    }).catch(function (error) {console.log("error=>"+error);    });

示例2:Base64解碼

bce3cdb2-e6c8-11ec-ba43-dac502259ad0.gif

本示例通過ByteString實現(xiàn)Base64解碼功能,代碼如下:
let byteStringObj = new okio.ByteString.ByteString(''); //生成ByteString對象let decodeBase64 = byteStringObj.decodeBase64('SGVsbG8gd29ybGQ='); //解碼Base64字符串this.decodeBase64Value = JSON.stringify(decodeBase64); //顯示解碼結果
示例3:十六進制解碼

bd4c4dce-e6c8-11ec-ba43-dac502259ad0.gif

本示例通過ByteString實現(xiàn)十六進制解碼功能,代碼如下:
let byteStringObj = new okio.ByteString.ByteString('');let decodehex = byteStringObj.decodeHex('48656C6C6F20776F726C640D0A');this.decodeHexValue = JSON.stringify(decodehex);
示例4:Utf8編碼

bd746d04-e6c8-11ec-ba43-dac502259ad0.gif

本示例通過ByteString實現(xiàn)Utf8編碼功能,代碼如下:
let byteStringObj = new okio.ByteString.ByteString('');let encodeUtf8 = byteStringObj.encodeUtf8('Hello world #4  ( ????? ??)');this.encodeUtf8Value = JSON.stringify(encodeUtf8);

本期okio組件就為大家介紹到這里了。okio組件已開源,歡迎大家參與貢獻。

開源地址如下:

https://gitee.com/openharmony-tpc/okio還想了解更多優(yōu)秀的組件?歡迎點擊下方的“閱讀原文”,跳轉到三方組件庫,更多優(yōu)秀組件等你來發(fā)現(xiàn)!

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 組件
    +關注

    關注

    1

    文章

    529

    瀏覽量

    18291
  • HarmonyOS
    +關注

    關注

    79

    文章

    2052

    瀏覽量

    32110

原文標題:為你推薦一款高效的IO組件——okio

文章出處:【微信號:HarmonyOS_Dev,微信公眾號:HarmonyOS開發(fā)者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    HarmonyOS5云服務技術分享--云數(shù)據(jù)使用指南

    ??: 敏感數(shù)據(jù)啟用字段級加密(如用戶手機號)。 ? ??總結?? 華為云數(shù)據(jù)(CloudDB)讓HarmonyOS應用的數(shù)據(jù)管理變得輕松又高效!通過本文的代碼示例和技巧,相信你已經(jīng)掌握了增刪改查
    發(fā)表于 05-22 18:29

    Profinet 協(xié)議遠程 IO 模塊:端子機高效運行的關鍵助手

    在電線加工領域,端子機的高效穩(wěn)定運行至關重要。如今,項先進的技術 ——Profinet 協(xié)議遠程 IO 模塊,正悄然改變著端子機的控制模式,為其高效工作注入強大動力。?
    的頭像 發(fā)表于 03-21 17:36 ?241次閱讀
    Profinet 協(xié)議遠程 <b class='flag-5'>IO</b> 模塊:端子機<b class='flag-5'>高效</b>運行的關鍵助手

    分布式 IO 模塊:水力發(fā)電設備高效控制的關鍵

    在能源領域不斷追求高效與可持續(xù)發(fā)展的今天,水力發(fā)電作為種清潔、可再生的能源形式,備受關注。而要實現(xiàn)水力發(fā)電設備的高效運行,精準的控制技術至關重要。分布式 IO 模塊,正悄然成為水力發(fā)
    的頭像 發(fā)表于 02-20 15:49 ?309次閱讀
    分布式 <b class='flag-5'>IO</b> 模塊:水力發(fā)電設備<b class='flag-5'>高效</b>控制的關鍵

    迅為瑞芯微RK3562開發(fā)板/核心板介紹可應用于人臉跟蹤、視頻監(jiān)控、自動語音識別(ASR)等

    可應用于人臉跟蹤、身體跟蹤、視頻監(jiān)控、自動語音識別(ASR)、圖像分類駕駛員輔助系統(tǒng)(ADAS)、車牌識別、物體識別等。 iTOP-3562開發(fā)板/核心板采用瑞芯微RK3562處理器,內(nèi)部集成了四核
    發(fā)表于 02-18 14:46

    HarmonyOS 應用開發(fā)賦能套件:鴻蒙原生應用開發(fā)的 “神助攻”

    隨著鴻蒙生態(tài)的快速發(fā)展,越來越多的開發(fā)者投身于鴻蒙原生應用的開發(fā)中。然而,在學習鴻蒙原生應用開發(fā)時,許多開發(fā)者仍面臨系列問題,如不清楚如何快速入門,如何系統(tǒng)地學習并掌握開發(fā)技能,如何高效獲取樣例
    發(fā)表于 02-17 16:37

    分布式 IO:礦山砂石裝備高效控制的新引擎

    在砂石與礦山行業(yè)這片充滿挑戰(zhàn)與機遇的領域,裝備的高效運行和精準控制直是企業(yè)追求的核心目標。隨著科技的飛速發(fā)展,明達技術推出的MR30分布式 IO 模塊作為種先進的控制技術,正逐漸嶄
    的頭像 發(fā)表于 02-12 17:08 ?272次閱讀

    Profinet IO通信故障原因及解決辦法

    Profinet IO(Industrial Ethernet for Automation)作為種高性能的工業(yè)以太網(wǎng)通信協(xié)議,廣泛應用于工業(yè)自動化領域。然而,在實際應用中,Profinet
    的頭像 發(fā)表于 02-03 14:50 ?1215次閱讀

    AKI跨語言調(diào)用神助攻C/C++代碼遷移至HarmonyOS NEXT

    本帖最后由 HarmonyOS開發(fā)者社區(qū) 于 2025-1-3 15:41 編輯 隨著HarmonyOS NEXT的發(fā)布,越來越多的應用加速推進鴻蒙化。在這過程中,如何高效遷移
    發(fā)表于 01-02 17:08

    MR20體式IO模塊助力折彎機高效控制

    在工業(yè)生產(chǎn)中,折彎機作為鈑金加工的重要設備,其控制系統(tǒng)的性能直接影響生產(chǎn)效率和產(chǎn)品質(zhì)量。今天,我們就來了解下如何通過明達技術MR20體式IO模塊實現(xiàn)折彎機的高效控制,為企業(yè)創(chuàng)造更多
    的頭像 發(fā)表于 12-12 14:25 ?401次閱讀
    MR20<b class='flag-5'>一</b>體式<b class='flag-5'>IO</b>模塊助力折彎機<b class='flag-5'>高效</b>控制

    HarmonyOS開發(fā)寶典震撼來襲,卓越應用開發(fā)之旅觸即發(fā),輕松啟程!

    HarmonyOS賦能產(chǎn)品,全面護航開發(fā)者從HarmonyOS感知、學習進階、開發(fā)實踐至技術支持的全旅程,助力開發(fā)者高效開發(fā)! 我們傾心打造了
    發(fā)表于 12-05 08:57

    λ-IO:存儲計算下的IO棧設計

    動機和背景? ? 存儲計算存儲資源的充分利用。IO棧是管理存儲器的的基本組件,包括設備驅(qū)動、塊接口層、文件系統(tǒng),目前些用戶空間IO(如SPDK)有效降低了延遲,但是
    的頭像 發(fā)表于 12-02 10:35 ?550次閱讀
    λ-<b class='flag-5'>IO</b>:存儲計算下的<b class='flag-5'>IO</b>棧設計

    AWTK 最新動態(tài):支持鴻蒙系統(tǒng)(HarmonyOS Next)

    為ToolkitAnyWhere,是ZLG傾心打造的套基于C語言開發(fā)的GUI框架。旨在為用戶提供功能強大、高效可靠、簡單易用、可輕松做出炫酷效果的GUI引擎,支
    的頭像 發(fā)表于 11-06 08:03 ?703次閱讀
    AWTK 最新動態(tài):支持鴻蒙系統(tǒng)(<b class='flag-5'>HarmonyOS</b> Next)

    FS2957X可應用于電動自行車快速充電轉換頭方案

    FS2957X可應用于電動自行車快速充電轉換頭方案,詳情可查閱FS2957X+協(xié)議芯片可實現(xiàn)電動車給手機快充。原廠提供DEMO測試,方案開發(fā)及技術支持! FS2957X是款120V寬電壓降壓DC-DC電源芯片,外置NMOS+1肖特基、外圍相當精簡、采用 ESOP-
    的頭像 發(fā)表于 09-10 18:28 ?516次閱讀
    FS2957X<b class='flag-5'>可應用于</b>電動自行車快速充電轉換頭方案

    為什么用于接收的IO口無法觸發(fā)中斷?

    我的代碼邏輯大概是“串口收到數(shù)據(jù)后控制IO口發(fā)出高低電平,用另外IO口接收這個高低電平”
    發(fā)表于 06-25 08:14

    遠程IO與分布式IO的區(qū)別

    在工業(yè)自動化和控制系統(tǒng)設計中,遠程IO(Input/Output)和分布式IO是兩重要的概念。它們各自具有獨特的特點和優(yōu)勢,適用于不同的應用場景。本文將詳細探討遠程
    的頭像 發(fā)表于 06-15 15:57 ?3740次閱讀