在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

鴻蒙開發學習:【方舟開發框架容器類API的介紹與使用】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-05-13 16:45 ? 次閱讀

一、容器類API介紹

方舟開發框架中,提供了線性非線性兩類容器類,共14種,每種容器都有自身的特性及使用場景。下面,我們將為大家一一道來。

鴻蒙開發指導文檔:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

線性容器類

線性容器類底層主要通過數組實現,包括ArrayList、Vector、List、LinkedList、Deque、Queue、Stack七種。線性容器類API,充分考慮了數據訪問的速度,運行時(Runtime)通過一條字節碼指令就可以完成增刪改查等操作。

1. ArrayList

ArrayList即動態數組,可用來構造全局的數組對象。ArrayList依據泛型定義,要求存儲位置是一片連續的內存空間,初始容量大小為10,并支持動態擴容,每次擴容大小為原始容量的1.5倍。ArrayList進行增、刪、改、查操作的相關API如下:

image.png

2. Vector

Vector 是指連續存儲結構,可用來構造全局的數組對象。Vector依據泛型定義,要求存儲位置是一片連續的內存空間,初始容量大小為10,并支持動態擴容,每次擴容大小為原始容量的2倍。

由于Vector擴容速度高于ArrayList,所以適用于數據添加比較頻繁的場景。Vector在支持操作符訪問的基礎上,還增加了get/set接口,提供更為完善的校驗及容錯機制,滿足用戶不同場景下的需求。Vector進行增、刪、改、查操作的相關API如下:

image.png

3. List

List可用來構造一個單向鏈表對象,即只能通過頭結點開始訪問到尾節點。List依據泛型定義,在內存中的存儲位置可以是不連續的。

可以通過get/set等接口對存儲的元素進行修改,List進行增、刪、改、查操作的相關API如下:
image.png

4. LinkedList

LinkedList可用來構造一個雙向鏈表對象,可以在某一節點向前或者向后遍歷List。LinkedList依據泛型定義,在內存中的存儲位置可以是不連續的。

可以通過get/set等接口對存儲的元素進行修改,LinkedList進行增、刪、改、查操作的相關API如下:

image.png

5. Queue

Queue可用來構造隊列對象,存儲元素遵循先進先出的規則。Queue依據泛型定義,要求存儲位置是一片連續的內存空間,初始容量大小為8,并支持動態擴容,每次擴容大小為原始容量的2倍。Queue底層采用循環隊列實現,入隊及出隊操作效率都比較高。Queue進行增、刪、改、查操作的相關API如下:

image.png

6. Deque

Deque可用來構造雙端隊列對象,存儲元素遵循先進先出的規則,雙端隊列可以分別從對頭或者隊尾進行訪問。Deque依據泛型定義,要求存儲位置是一片連續的內存空間,其初始容量大小為8,并支持動態擴容,每次擴容大小為原始容量的2倍。Deque底層采用循環隊列實現,入隊及出隊操作效率都比較高。Deque進行增、刪、改、查操作的相關API如下:

image.png

7. Stack

Stack可用來構造棧對象,存儲元素遵循后進先出的規則。Stack依據泛型定義,要求存儲位置是一片連續的內存空間,初始容量大小為8,并支持動態擴容,每次擴容大小為原始容量的1.5倍。Stack底層基于數組實現,入棧出棧均從數組的一端操作,Stack進行增、刪、改、查操作的相關API如下:image.png

非線性容器類

非線性容器類底層通過hash或者紅黑樹實現,包括HashMap、HashSet、TreeMap、TreeSet、LightWeightMap、LightWeightSet、PlainArray七種。非線性容器類中的key及value的類型均滿足ECMA標準。

1. HashMap

HashMap可用來存儲具有關聯關系的key-value鍵值對集合,存儲元素中key是唯一的,每個key會對應一個value值。HashMap依據泛型定義,集合中通過key的hash值確定其存儲位置,從而快速找到鍵值對。HashMap的初始容量大小為16,并支持動態擴容,每次擴容大小為原始容量的2倍。HashMap底層基于HashTable實現,沖突策略采用鏈地址法。HashMap進行增、刪、改、查操作的相關API如下:image.png

2. HashSet

HashSet可用來存儲一系列值的集合,存儲元素中value是唯一的。依據泛型定義。集合中通過value的hash值確定其存儲位置,從而快速找到該值。HashSet初始容量大小為16,支持動態擴容,每次擴容大小為原始容量的2倍。value的類型滿足ECMA標準中要求的類型。HashSet底層基于HashTable實現,沖突策略采用鏈地址法。HashSet進行增、刪、改、查操作的相關API如下:

image.png

3. TreeMap

TreeMap可用來存儲具有關聯關系的key-value鍵值對集合,存儲元素中key是唯一的,每個key會對應一個value值。TreeMap依據泛型定義,集合中的key值是有序的,TreeMap的底層是一棵二叉樹,可以通過樹的二叉查找快速的找到鍵值對。key的類型滿足ECMA標準中要求的類型。TreeMap中的鍵值是有序存儲的。TreeMap底層基于紅黑樹實現,可以進行快速的插入和刪除。TreeMap進行增、刪、改、查操作的相關API如下:

image.png

4. TreeSet

TreeSet可用來存儲一系列值的集合,存儲元素中value是唯一的。TreeSet依據泛型定義,集合中的value值是有序的,TreeSet的底層是一棵二叉樹,可以通過樹的二叉查找快速的找到該value值,value的類型滿足ECMA標準中要求的類型。TreeSet中的值是有序存儲的。TreeSet底層基于紅黑樹實現,可以進行快速的插入和刪除。TreeSet進行增、刪、改、查操作的相關API如下:

image.png

5. LightWeightMap

LigthWeightMap可用來存儲具有關聯關系的key-value鍵值對集合,存儲元素中key是唯一的,每個key會對應一個value值。LigthWeightMap依據泛型定義,采用更加輕量級的結構,集合中的key值的查找依賴于hash值以及二分查找算法,通過一個數組存儲hash值,然后映射到其他數組中的key值以及value值,key的類型滿足ECMA標準中要求的類型。

初始默認容量大小為8,每次擴容大小為原始容量的2倍。LigthWeightMap底層標識唯一key通過hash實現,其沖突策略為線性探測法,查找策略基于二分查找法。LigthWeightMap進行增、刪、改、查操作的相關API如下:

image.png

6. LightWeightSet

LigthWeightSet可用來存儲一系列值的集合,存儲元素中value是唯一的。LigthWeightSet依據泛型定義,采用更加輕量級的結構,初始默認容量大小為8,每次擴容大小為原始容量的2倍。集合中的value值的查找依賴于hash以及二分查找算法,通過一個數組存儲hash值,然后映射到其他數組中的value值,value的類型滿足ECMA標準中要求的類型。

LigthWeightSet底層標識唯一value基于hash實現,其沖突策略為線性探測法,查找策略基于二分查找法。LigthWeightSet進行增、刪、改、查操作的相關API如下:

image.png

7. PlainArray

PlainArray可用來存儲具有關聯關系的鍵值對集合,存儲元素中key是唯一的,并且對于PlainArray來說,其key的類型為number類型。每個key會對應一個value值,類型依據泛型的定義,PlainArray采用更加輕量級的結構,集合中的key值的查找依賴于二分查找算法,然后映射到其他數組中的value值。

初始默認容量大小為16,每次擴容大小為原始容量的2倍。PlainArray的查找策略基于二分查找法。PlainArray進行增、刪、改、查操作的相關API如下:

image.png

二、容器類的實現

下面我們將以ArrayList為例,為大家介紹,容器類的實現。包括容器類的初始化、容器類的接口調用、容器類對象模型的構建以及攔截器處理。

容器類初始化

在方舟開發框架中,通過NAPI的統一框架對外層提供容器類。下面,我們將以ArrayList為例,介紹基于NAPI的容器類的加載。如下圖所示,是容器類初始化流程,在NAPI加載的過程中,會通過ArkPrivate.Load接口加載對應的容器類。ArrayList在引擎中會初始化Constructor以及Prototype并返回,最后應用側可以獲得該容器類并使用。

image.png

圖1 容器類初始化流程

容器類接口調用

在方舟開發框架中,容器類API的調用流程如圖2所示,用戶先通過new ArrayList進入引擎得到對應的arraylist對象,然后可以通過add接口向對象中添加元素,元素最終會添加到一片和該arraylist綁定的內存空間。可以通過[]操作符進行元素獲取,對于容器類而言,引擎會直接通過快速路徑訪問到元素存儲位置,返回該值。

image.png

圖2 容器類API的調用流程

容器類對象模型

在方舟開發框架中,構造容器類對象模型的流程如下圖所示,在運行時禁止再向對象上添加Properties屬性,ArrayList借用對象模型中的elements位置存儲元素。

image.png

圖3 容器類對象模型的構造流程

實現說明:通過elements存儲數組元素,Length為數組中元素個數,數組Capatity可以通過elements的長度獲取。

擴容策略:ArrayList –> 1.5倍

初始分配容量:ArrayList -> 10

(注:TS中的實現,擴容策略及初始分配容量不感知)

攔截器處理

攔截器處理,是指通過禁止掉一些影響對象行為的操作,比如delete、setPrototype等,在運行時(Runtime)維護一個高效的容器類對象。如圖4所示,以ArrayList為例,ArkCompiler內部攔截的操作主要涉及DeleteProperty、DefineProperty、GetProperty、SetPrototype、GetOwnPropertyKeys、HasProperty等操作限制數組的holy添加,以及更改屬性的attributes等操作,保證了不需要做JSArray必須做的holy 判斷、writable 判斷等操作。

image.png

圖4 攔截器處理

HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿

搜狗高速瀏覽器截圖20240326151450.png
三、容器類API的使用

通過上文的介紹,相信大家對容器類已經有了比較深刻的認識。那么,我們怎么使用容器類API呢?本文列舉常用的典型容器的使用示例,包括導入模塊、增加元素、訪問元素及修改等操作:

// ArrayList  
import ArrayList from '@ohos.util.ArrayList' // 導入ArrayList模塊  
let arrayList = new ArrayList();  
arrayList.add("a");  
arrayList.add(1); // 增加元素  
print(arrayList[0]); // 訪問元素  
arrayList[0] = one"; // 修改元素  
print(arrayList[0]);

// Vector  
import Vector from '@ohos.util.Vector' // 導入Vector模塊  
let vector = new Vector();  
vector.add("a");  
let b = [1, 2, 3];  
vector.add(b);  
vector.add(false); // 增加元素  
print(vector[0]); // 訪問元素  
print(vector.getFirstElement()); // 訪問元素

// Deque  
import Deque from '@ohos.util.Deque' // 導入Deque模塊  
let deque = new Deque;  
deque.insertFront("a");  
deque.insertFront(1); // 增加元素  
print(deque[0]); // 訪問元素  
deque[0] = "one"; // 修改元素  
print(deque[0]);

// Stack  
import Stack from '@ohos.util.Stack' // 導入Stack模塊  
let stack = new Stack();  
stack.push("a");  
stack.push(1); // 增加元素  
print(stack[0]); // 訪問元素  
stack.pop(); // 彈出元素  
print(stack.length);

// List  
import List from '@ohos.util.List' // 導入List模塊  
let list = new List;  
list.add("a");  
list.add(1);  
let b = [1, 2, 3];  
list.add(b); // 增加元素  
print(list[0]); // 訪問元素  
print(list.get(0)); // 訪問元素

// HashMap  
import HashMap from '@ohos.util.HashMap' // 導入HashMap模塊  
let hashMap = new HashMap();  
hashMap.set("a", 123);  
hashMap.set(4, 123); // 增加元素  
print(hashMap.hasKey(4)); // 判斷是否含有某元素  
print(hashMap.get("a")); // 訪問元素

// TreeMap  
import TreeMap from '@ohos.util.TreeMap' // 導入TreeMap模塊  
let treeMap = new TreeMap();  
treeMap.set("a", 123);  
treeMap.set("6", 356); // 增加元素  
print(treeMap.get("a")); // 訪問元素  
print(treeMap.getFirstKey("a")); // 訪問首元素  
print(treeMap.getLastKey("a")); // 訪問尾元素

// LightWeightMap  
import LightWeightMap from '@ohos.util.LightWeightMap' // 導入LightWeightMap模塊  
let lightWeightMap = new LightWeightMap();  
lightWeightMap.set("x", 123);  
lightWeightMap.set("8", 356); // 增加元素  
print(lightWeightMap.get("a")); // 訪問元素  
print(lightWeightMap.get("x")); // 訪問元素  
print(lightWeightMap.getIndexOfKey("8")); // 訪問元素

// PlainArray  
import PlainArray from '@ohos.util.PlainArray' // 導入PlainArray模塊  
let plainArray = new PlainArray();  
plainArray.add(1, "sdd");  
plainArray.add(2, "sff"); // 增加元素  
print(plainArray.get(1)); // 訪問元素  
print(plainArray.getKeyAt(1)); // 訪問元素

審核編輯 黃宇

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

    關注

    2

    文章

    1512

    瀏覽量

    62417
  • 鴻蒙
    +關注

    關注

    57

    文章

    2393

    瀏覽量

    43072
收藏 人收藏

    評論

    相關推薦

    鴻蒙開發:【OpenHarmony 4.0 Release指導】

    OpenHarmony 4.0版本如期而至,開發套件同步升級到API 10。相比3.2 Release版本,新增4000多個API,應用開發能力更加豐富;HDF新增200多個HDI接口
    的頭像 發表于 05-14 09:59 ?1649次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發</b>:【OpenHarmony 4.0 Release指導】

    HarmonyOS應用開發-JS相關整體梳理

    方舟開發框架是一種跨設備的高性能UI開發框架,支持聲明式編程和跨設備多態UI。基礎能力Web范
    發表于 11-29 10:44

    HarmonyOS方舟開發框架容器API介紹與使用

    API的使用。 一、容器API介紹方舟開發
    發表于 03-07 11:40

    OpenHarmony 3.1 Beta版本關鍵特性解析——ArkUI容器API介紹

    ,我們將為大家介紹 ArkUI 開發框架容器的各種類型以及相關 API 的使用。一、
    發表于 04-24 14:58

    HarmonyOS/OpenHarmony應用開發-Web開發范式

    兼容JS的Web開發范式的方舟開發框架,采用經典的HML、CSS、JavaScript三段式開發
    發表于 01-18 19:15

    OpenHarmony應用開發-ArkUI方舟開發框架簡析

    方舟開發框架提供了兩種開發范式,分別是基于ArkTS的聲明式開發范式(簡稱“聲明式開發范式”)
    發表于 04-23 09:35

    OpenHarmony 應用開發SDK、API 與基礎工具

    類似于 ArkTS API 上的完整鴻蒙平臺能力,開發者可以使用 C API 開發支持鴻蒙應用
    發表于 09-19 15:45

    android框架與應用開發介紹

    android框架與應用開發介紹
    發表于 10-24 09:35 ?7次下載
    android<b class='flag-5'>框架</b>與應用<b class='flag-5'>開發</b><b class='flag-5'>介紹</b>

    要成為鴻蒙開發者,應該學習哪些編程語言

    據了解,鴻蒙系統是基于Linux開發的,源碼是C語言。那么,作為一名開發者,如何幫助鴻蒙系統構建生態呢?在以往安卓、蘋果系統構建過程,有哪些可以值得借鑒的地方呢?要成為
    的頭像 發表于 09-24 12:06 ?1.3w次閱讀

    華為開發者大會2021_方舟開發有效提升開發效率

    華為開發者大會2021中,重點闡述了方舟開發框架,此框架有效的提升開發效率。
    的頭像 發表于 10-22 15:17 ?1424次閱讀
    華為<b class='flag-5'>開發</b>者大會2021_<b class='flag-5'>方舟</b><b class='flag-5'>開發</b>有效提升<b class='flag-5'>開發</b>效率

    方舟開發框架(Ark UI)概述及開發實戰

    本期要為大家介紹的是ArkUI入門課程——HarmonyOS技術訓練營第四期《方舟開發框架(Ark UI)概述及開發實戰》。相信
    的頭像 發表于 12-17 14:49 ?8357次閱讀

    方舟開發框架容器的各種類型

    屬性的限制,讓每種類型的數據都能在完成自身功能的基礎上剪除冗余分支,保證了數據的高效訪問,提升了應用的性能。本期,我們將為大家介紹方舟開發框架容器
    的頭像 發表于 03-14 13:45 ?1627次閱讀
    <b class='flag-5'>方舟</b><b class='flag-5'>開發</b><b class='flag-5'>框架</b>中<b class='flag-5'>容器</b><b class='flag-5'>類</b>的各種類型

    OpenHarmony 3.1 Beta版本關鍵特性解析——ArkUI開發框架容器API介紹與使用

    線性容器底層主要通過數組實現,包括 ArrayList、Vector、List、LinkedList、Deque、Queue、Stack 七種。線性容器
    的頭像 發表于 03-17 10:48 ?918次閱讀

    鴻蒙開發用什么語言?

    兩種開發方向 我們常說鴻蒙開發,但是其實鴻蒙開發分為兩個方向: 一個是系統級別的開發,比如驅動,
    的頭像 發表于 01-30 16:12 ?1635次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發</b>用什么語言?

    鴻蒙ArkUI-X框架開發:【開發準備】

    本文檔適用于ArkUI-X框架開發的初學者。通過環境搭建、代碼下載、代碼編譯、API擴展和使用,快速了解跨平臺項目開發流程。
    的頭像 發表于 05-23 21:02 ?527次閱讀
    <b class='flag-5'>鴻蒙</b>ArkUI-X<b class='flag-5'>框架開發</b>:【<b class='flag-5'>開發</b>準備】
    主站蜘蛛池模板: 日本免费xxxx色视频 | 国产caoni111在线观看视频 | 久综合色| 亚洲人成网站在线观看妞妞网 | 日韩毛片免费视频一级特黄 | 亚洲成人午夜影院 | 色性综合 | 被公侵犯肉体中文字幕一区二区 | 国产片一级特黄aa的大片 | 美国一级毛片不卡无毒 | 真人一级一级特黄高清毛片 | 亚洲色图22p | 日韩在线天堂免费观看 | 国产日韩欧美综合色视频在线 | 亚洲无线码一区在线观看 | 欧美福利视频网站 | aa视频在线 | 中文字幕亚洲一区二区v@在线 | 亚洲香蕉影视在线播放 | 国内自拍2021 | 欧美性猛片xxxxⅹ免费 | 免费看欧美一级特黄α大片 | 免费高清在线爱做视频 | 亚欧人成精品免费观看 | 国产理论视频在线观看 | 69er小视频 | 2023天天操 | 一本在线免费视频 | 九九精品久久久久久噜噜 | 双性人皇上被c到哭 | 亚洲一区二区免费视频 | www深夜视频在线观看高清 | 亚洲午夜视频在线 | 最新版天堂中文在线官网 | 手机看片国产免费永久 | 欧美国产黄色 | 日本福利片午夜免费观着 | 色吧视频 | 午夜色a大片在线观看免费 午夜色大片在线观看 | 欧美卡一卡二卡新区网站 | 天天操天天玩 |