国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

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

HarmonyOS開發者 ? 來源:HarmonyOS開發者 ? 作者:HarmonyOS開發者 ? 2022-06-08 09:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前不久,三方組件庫上新了一批JS/eTS組件,其中就包括okio組件。okio是一個可應用于HarmonyOS的高效IO庫,它依托于系統能力,提供字符串的編解碼轉換能力,基礎數據類型的讀寫能力以及對文件讀寫的支持。本期將為大家介紹okio的工作原理及使用方法。

一、okio的產生背景

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

二、兩個基本概念

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

1. Segment

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

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

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

三、okio的工作原理

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

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

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

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

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

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

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

圖2 Segment拆分

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

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

(1) take()方法

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

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

  • 當前Segment是共享的

  • 對象池已經有8個Segment了

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

四、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. 代碼實現執行完上面的配置操作后,就可以進入代碼編寫階段了。開發者可以使用okio提供的豐富的API接口來實現功能。下面為大家展示四個實現示例,供大家參考學習。

示例1:文件寫入和讀取

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

本示例通過sink將內容寫入文件,通過source從文件讀取內容。代碼如下:
//通過sink將內容寫入文件var sink = new okio.Sink(this.fileUri);sink.write(this.Value,false); //通過source從文件讀取內容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實現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實現十六進制解碼功能,代碼如下:
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實現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還想了解更多優秀的組件?歡迎點擊下方的“閱讀原文”,跳轉到三方組件庫,更多優秀組件等你來發現!

審核編輯 :李倩


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

    關注

    1

    文章

    573

    瀏覽量

    19023
  • HarmonyOS
    +關注

    關注

    80

    文章

    2153

    瀏覽量

    36058

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    三格電子體式io和分體式io的區別#

    IO
    jf_68793483
    發布于 :2026年02月27日 14:15:48

    菲諾克科技推出沁恒CH9347有線透傳芯片應用于移動電源新國標方案

    菲諾克科技推出沁恒CH9347有線透傳芯片應用于移動電源新國標方案 菲諾克科技根據新國標移動電源與各類終端便捷通信的核心需求,采用沁恒USB透傳芯片CH9347推出了充電寶USB通信、低功耗藍牙
    發表于 02-10 09:10

    恒訊科技解析:如何安裝MySQL并創建數據

    管理系統(RDBMS),使用結構化查詢語言(SQL)高效地組織和管理數據。它是全球最受歡迎的開源數據系統之,廣泛應用于網頁開發、電子商務和商業應用。 常見用例? MySQL 是多種
    的頭像 發表于 01-14 14:25 ?179次閱讀

    釘釘正式開源HarmonyOS圖片編輯組件

    近日,由釘釘團隊自主研發的“HarmonyOS圖片編輯組件”正式上線OpenHarmony三方中心倉并開源。作為款填補鴻蒙社區圖像處理領域空白的重量級組件,該方案基于HarmonyOS
    的頭像 發表于 01-05 09:58 ?501次閱讀

    圣邦微電子發布高效率LED驅動芯片SGM37601

    圣邦微電子推出SGM37601,款六通道40V高效率LED驅動芯片。該器件可應用于平板電腦和筆記本電腦等中尺寸LCD顯示屏設備。
    的頭像 發表于 12-12 17:20 ?3070次閱讀
    圣邦微電子發布<b class='flag-5'>高效</b>率LED驅動芯片SGM37601

    超實用!頁搞定威綸通IO顯示

    IO監控畫面是自動化設備中用于快速診斷故障的常用功能。然而,當設備IO點數量眾多時,往往需要配置多個監控畫面,這過程不僅繁瑣易錯,也降低了排查效率。 那么,能否在
    的頭像 發表于 11-12 15:42 ?734次閱讀
    超實用!<b class='flag-5'>一</b>頁搞定威綸通<b class='flag-5'>IO</b>顯示

    GraniStudio:IO寫入例程

    說明 實現輸出IO控制以及讀取。 2.1通過初始化IO算子連接格拉尼控制器IO塊,導入工程自動進行連接。 2.2 通過IO配置算子輸出配置的IO
    的頭像 發表于 08-22 16:47 ?769次閱讀
    GraniStudio:<b class='flag-5'>IO</b>寫入例程

    Aisler 發布 Lovely Library:為 KiCad 打造的高質量歐洲元器件

    “ ?看到 Aisler 的推文,覺得挺搞笑的,原來元器件也可以有地域之分;?不過對用戶來說,更多的高質量器件定會讓設計更高效。好東西還是要分享!? ” ? 以上的內容翻譯如下:
    的頭像 發表于 08-04 11:13 ?896次閱讀
    Aisler 發布 Lovely Library:<b class='flag-5'>一</b><b class='flag-5'>個</b>為 KiCad 打造的高質量歐洲元器件<b class='flag-5'>庫</b>

    模塊通吃DI/DO/AI/AO!無線IO的萬能信號采集方案

    無線IO通訊模塊是種特殊的輸入輸出(I/O)設備,它采用無線通訊技術實現I/O信號的傳輸。以下是對無線IO通訊模塊的詳細介紹: 、定義與功能 定義:無線
    的頭像 發表于 07-22 10:15 ?611次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b>模塊通吃DI/DO/AI/AO!無線<b class='flag-5'>IO</b>的萬能信號采集方案

    文詳解Advanced IO wizard異步模式

    7nm Versal系列相對于16nm Ultrascale plus系列,IO做了升級,U+系列的HPIO在Versal升級為XPIO。Versal系列每一個XPIO bank包含54IO
    的頭像 發表于 07-11 09:52 ?1569次閱讀
    <b class='flag-5'>一</b>文詳解Advanced <b class='flag-5'>IO</b> wizard異步模式

    HarmonyOS入門指南

    上手的HarmonyOS工具,借助眾多實用工具類,致力于助力開發者迅速構建鴻蒙應用。 2、開源框架 harmony-utils 款功能豐富且極易上手的HarmonyOS工具
    的頭像 發表于 06-27 00:11 ?792次閱讀

    HarmonyOS實戰:3秒實現自定義輪播圖

    那么簡單,需要考慮的細節很多。不過在 HarmonyOS 中實現輪播圖卻是十分的簡單,本篇文章教你在最短的時間內快速實現自定義的 輪
    的頭像 發表于 06-24 17:06 ?1512次閱讀

    HarmonyOS5云服務技術分享--云數據使用指南

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

    體式 IO 模塊:線纜設備車間高效控制的新引擎

    在當今競爭激烈的制造業環境中,線纜設備車間面臨著提高生產效率、降低成本和提升產品質量的多重挑戰。實現高效的自動化控制成為了車間突破發展瓶頸的關鍵,而明達技術MR20體式 IO 模塊的出現,為線纜設備車間帶來了全新的解決方案。
    的頭像 發表于 03-25 11:15 ?647次閱讀
    <b class='flag-5'>一</b>體式 <b class='flag-5'>IO</b> 模塊:線纜設備車間<b class='flag-5'>高效</b>控制的新引擎

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

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