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

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

3天內不再提示

鴻蒙語言基礎類庫:ohos.util.Vector 線性容器Vector

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-07-11 09:56 ? 次閱讀

線性容器Vector

說明: 本模塊首批接口從API version 8開始支持。后續(xù)版本的新增接口,采用上角標單獨標記接口的起始版本。 開發(fā)前請熟悉鴻蒙開發(fā)指導文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

Vector是一種線性數(shù)據(jù)結構,底層基于數(shù)組實現(xiàn)。當Vector的內存用盡時,會自動分配更大的連續(xù)內存區(qū),將原先的元素復制到新的內存區(qū),并釋放舊的內存區(qū)。使用Vector能夠高效快速地訪問元素。

Vector和[ArrayList]相似,都是基于數(shù)組實現(xiàn),但Vector提供了更多操作數(shù)組的接口。它們都可以動態(tài)調整容量,但Vector每次擴容增加1倍,ArrayList只擴容0.5倍。

推薦使用場景: 當數(shù)據(jù)量大時,一般使用Vector來存取數(shù)據(jù)。

導入模塊

import Vector from '@ohos.util.Vector';

Vector

屬性

系統(tǒng)能力: SystemCapability.Utils.Lang

名稱參數(shù)類型可讀可寫說明
lengthnumberVector的元素個數(shù)。

constructor

constructor()

Vector的構造函數(shù)。

系統(tǒng)能力: SystemCapability.Utils.Lang

示例:

let vector = new Vector();

add

add(element: T): boolean

在Vector中尾部插入元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT添加進去的元素。

返回值:

類型說明
boolean插入成功返回true,失敗返回false。

示例:

let vector = new Vector();
let result = vector.add("a");
let result1 = vector.add(1);
let b = [1, 2, 3];
vector.add(b);
let c = {name : "lala", age : "13"};
let result3 = vector.add(c);

insert

insert(element: T, index: number): void

在長度范圍內任意插入指定元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT被插入的元素。
indexnumber被插入的位置索引

示例:

let vector = new Vector();
vector.insert("A", 0);
vector.insert(0, 1);
vector.insert(true, 2);

has

has(element: T): boolean

判斷此Vector中是否含有該指定元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT指定的元素。

返回值:

類型說明
boolean是否包含指定元素。

示例:

let vector = new Vector();
let result = vector.has("Ahfbrgrbgnutfodgorrogorgrogofdfdf");
vector.add("Ahfbrgrbgnutfodgorrogorgrogofdfdf");
let result1 = vector.has("Ahfbrgrbgnutfodgorrogorgrogofdfdf");

getIndexOf

getIndexOf(element: T): number

返回指定元素第一次出現(xiàn)時的下標值,查找失敗返回-1。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT指定的元素。

返回值:

類型說明
number返回指定元素第一次出現(xiàn)時的下標值,查找失敗返回-1。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(2);
vector.add(1);
vector.add(2);
vector.add(4);
let result = vector.getIndexOf(2);

getLastIndexOf

getLastIndexOf(element: T): number

返回指定元素最后一次出現(xiàn)時的下標值,查找失敗返回-1。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT指定元素。

返回值:

類型說明
number返回指定元素最后一次出現(xiàn)時的下標值,查找失敗返回-1。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(2);
vector.add(1);
vector.add(2);
vector.add(4);
let result = vector.getLastIndexOf(2);

removeByIndex

removeByIndex(index: number): T

根據(jù)元素的下標值查找元素,返回元素后將其刪除。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
indexnumber指定元素的下標值。

返回值:

類型說明
T返回刪除的元素。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(2);
vector.add(4);
let result = vector.removeByIndex(2);

remove

remove(element: T): boolean

刪除查找到的第一個指定的元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT指定元素。

返回值:

類型說明
boolean刪除成功返回true,否則返回false。

返回值:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.remove(2);

removeByRange

removeByRange(fromIndex: number, toIndex: number): void

從一段范圍內刪除元素,包括起始值但不包括終止值。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
fromIndexnumber起始下標。
toIndexnumber終止下標。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.removeByRange(2,4);
vector.removeByRange(4,3);
vector.removeByRange(2,6);

replaceAllElements

replaceAllElements(callbackfn: (value: T, index?: number, vector?: Vector) => T, thisArg?: Object): void

用戶操作Vector中的元素,用操作后的元素替換原元素并返回操作后的元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
callbackfnfunction回調函數(shù)。
thisArgObjectcallbackfn被調用時用作this值。

callbackfn的參數(shù)說明:

參數(shù)名類型必填說明
valueT當前遍歷到的元素。
indexnumber當前遍歷到的下標值。
vectorVector當前調用replaceAllElements方法的實例對象。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.replaceAllElements((value: number, index: number) = > {
  return value = 2 * value;
});
vector.replaceAllElements((value: number, index: number) = > {
  return value = value - 2;
});

forEach

forEach(callbackfn: (value: T, index?: number, vector?: Vector) => void, thisArg?: Object): void

通過回調函數(shù)來遍歷Vector實例對象上的元素以及元素對應的下標。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
callbackfnfunction回調函數(shù)。
thisArgObjectcallbackfn被調用時用作this值。

callbackfn的參數(shù)說明:

參數(shù)名類型必填說明
valueT當前遍歷到的元素。
indexnumber當前遍歷到的下標值。
vectorVector當前調用forEach方法的實例對象。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.forEach((value, index) = > {
  console.log("value:" + value, index)
});

sort

sort(comparator?: (firstValue: T, secondValue: T) => number): void

對Vector中的元素進行一個排序操作。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
comparatorfunction回調函數(shù)。

comparator的參數(shù)說明:

參數(shù)名類型必填說明
firstValueT前一項元素。
secondValueT后一項元素。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.sort((a: number, b: number) = > a - b);
vector.sort((a: number, b: number) = > b - a);
vector.sort();

subVector

subVector(fromIndex: number, toIndex: number): Vector

根據(jù)下標截取Vector中的一段元素,并返回這一段vector實例,包括起始值但不包括終止值。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
fromIndexnumber起始下標。
toIndexnumber終止下標。

返回值:

類型說明
Vector返回Vector對象實例。

返回值:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.subVector(2,4);
let result1 = vector.subVector(4,3);
let result2 = vector.subVector(2,6);

clear

clear(): void

清除Vector中的所有元素,并把length置為0。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.clear();

clone

clone(): Vector

克隆一個與Vector相同的實例,并返回克隆后的實例。修改克隆后的實例并不會影響原實例。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
Vector返回Vector對象實例。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.clone();

getCapacity

getCapacity(): number

獲取當前實例的容量大小。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
number返回Vector的容量大小。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.getCapacity();

convertToArray

convertToArray(): Array

把當前Vector實例轉換成數(shù)組,并返回轉換后的數(shù)組。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
Array返回數(shù)組類型。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.convertToArray();

isEmpty

isEmpty(): boolean

判斷該Vector是否為空。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
boolean為空返回true,否則返回false。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.isEmpty();

increaseCapacityTo

increaseCapacityTo(newCapacity: number): void

如果傳入的新容量大于或等于Vector中的元素個數(shù),將容量變更為新容量。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
newCapacitynumber新容量。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.increaseCapacityTo(2);
vector.increaseCapacityTo(8);

trimToCurrentLength

trimToCurrentLength(): void

把容量限制為當前的length大小。

系統(tǒng)能力: SystemCapability.Utils.Lang

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.trimToCurrentLength();

toString

toString(): string

用","將Vector實例中的元素按順序拼接成字符串。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
string返回對應的字符串。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.toString();

copyToArray

copyToArray(array: Array): void

將Vector實例中的元素按照下標復制到指定數(shù)組。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
arrayArray指定數(shù)組。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let array = ["a", "b", "c", "d", "e", "f"];
let result = vector.copyToArray(array);

getFirstElement

getFirstElement(): T

獲取實例中的第一個元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
T返回第一個元素。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.getFirstElement();

getLastElement

getLastElement(): T

獲取Vector實例中的最后一個元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
T返回最后一個元素。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.getLastElement();

getLastIndexFrom

getLastIndexFrom(element: T, index: number): number

從指定索引向后搜索,返回該元素的下標索引。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT要查找的元素。
indexnumber從指定索引開始搜索。

返回值:

類型說明
number返回該元素的下標,如果查找失敗,則返回-1。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.add("a");
let result = vector.getLastIndexFrom(4,3);

getIndexFrom

getIndexFrom(element: T, index: number): number

從指定索引向前搜索,返回該元素的下標索引。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
elementT要查找的元素。
indexnumber從指定索引開始搜索。

返回值:

類型說明
number返回該元素的下標,如果查找失敗,則返回 -1。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.add("a");
let result = vector.getIndexFrom(4, 3);

setLength

setLength(newSize: number): void

設置Vector實例的元素個數(shù)。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
newSizenumber設置的新長度。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
vector.setLength(8);
vector.setLength(2);

get

get(index: number): T

根據(jù)下標值獲取Vector實例中的元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
indexnumber查找的下標值。

返回值:

類型說明
T返回獲取到的元素。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.get(2);

set

set(index: number, element: T): T

將此Vector中指定位置的元素替換為指定元素。

系統(tǒng)能力: SystemCapability.Utils.Lang

參數(shù):

參數(shù)名類型必填說明
indexnumber查找的下標值。
elementT用來替換的元素。

返回值:

類型說明HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿
T返回替換后的元素。

QQ截圖20240705211022.png
示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);
let result = vector.set(2, "A");

[Symbol.iterator]

Symbol.iterator: IterableIterator

返回一個迭代器,迭代器的每一項都是一個 JavaScript 對象,并返回該對象。

系統(tǒng)能力: SystemCapability.Utils.Lang

返回值:

類型說明
IterableIterator返回一個迭代器。

示例:

let vector = new Vector();
vector.add(2);
vector.add(4);
vector.add(5);
vector.add(4);

// 使用方法一:
for (let item of vector) { 
  console.log("value:" + item); 
} 

// 使用方法二:
let iter = vector[Symbol.iterator]();
let temp = iter.next().value;
while(temp != undefined) {
  console.log("value:" + temp);
  temp = iter.next().value;
}

審核編輯 黃宇

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

    關注

    3

    文章

    53

    瀏覽量

    8536
  • 鴻蒙
    +關注

    關注

    57

    文章

    2291

    瀏覽量

    42632
收藏 人收藏

    評論

    相關推薦

    c++之vector容器

    1.vector容器介紹 ? ? ? 向量(Vector)是一個封裝了動態(tài)大小數(shù)組的順序容器(Sequence Container)。跟任意其它類型
    的頭像 發(fā)表于 07-13 19:36 ?1336次閱讀
    c++之<b class='flag-5'>vector</b><b class='flag-5'>容器</b>

    OpenHarmony語言基礎【@ohos.util.Vector (線性容器Vector)】

    Vector是一種線性數(shù)據(jù)結構,底層基于數(shù)組實現(xiàn)。當Vector的內存用盡時,會自動分配更大的連續(xù)內存區(qū),將原先的元素復制到新的內存區(qū),并釋放舊的內存區(qū)。使用Vector能夠高效快速地
    的頭像 發(fā)表于 04-28 21:24 ?427次閱讀
    OpenHarmony<b class='flag-5'>語言</b>基礎<b class='flag-5'>類</b><b class='flag-5'>庫</b>【@<b class='flag-5'>ohos.util.Vector</b> (<b class='flag-5'>線性</b><b class='flag-5'>容器</b><b class='flag-5'>Vector</b>)】

    vector用法總結(轉載)

    一、vector的基本概念vector是同一種類型的對象的集合,每個對象都有一個對應的整數(shù)索引值。和string對象一樣,標準負責管理存儲元素的相關內存。我們把vector稱為
    發(fā)表于 05-01 15:22

    HarmonyOS方舟開發(fā)框架容器API的介紹與使用

    通過數(shù)組實現(xiàn),包括ArrayList、Vector、List、LinkedList、Deque、Queue、Stack七種。線性容器API,充分考慮了數(shù)據(jù)訪問的速度,實現(xiàn)了運行時(R
    發(fā)表于 03-07 11:40

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

    及使用場景。下面,我們將為大家一一道來。1.1線性容器線性容器底層主要通過數(shù)組實現(xiàn),包括 A
    發(fā)表于 04-24 14:58

    HarmonyOS線性容器特性及使用場景

    元素 console.info(`result: ${arrayList[0]}`); // Vector import Vector from \'@ohos.util.Vector\'; // 導入
    發(fā)表于 09-27 15:10

    Agilent Vector Signal Analysis

    This application note serves as a primer on the vector signal analyzer (VSA).This chapter discusses
    發(fā)表于 07-23 21:00 ?6次下載

    Vector

    DSP之Vector教程,很好的DSP自學資料,快來學習吧。
    發(fā)表于 04-15 17:49 ?11次下載

    C++ vector刪除符合條件元素的編程技巧

    C++ vector中實際刪除元素使用的是容器vecrot中std::vector::erase()方法。 C++ 中std::remove()并不刪除元素,因為容器的size()沒有
    的頭像 發(fā)表于 09-20 10:03 ?5338次閱讀

    Vector CANoe入門教程之基礎操作的詳細說明

    Vector-CANoe8.2基礎操作教程Vector-CANoe8.2基礎操作教程Vector-CANoe8.2基礎操作教程Vector-CANoe8.2基礎操作教程
    發(fā)表于 04-18 08:00 ?366次下載
    <b class='flag-5'>Vector</b> CANoe入門教程之基礎操作的詳細說明

    動態(tài)數(shù)組和C++ std::vector詳解

    std::vector是C++的默認動態(tài)數(shù)組,其與array最大的區(qū)別在于vector的數(shù)組是動態(tài)的,即其大小可以在運行時更改。std::vector是封裝動態(tài)數(shù)組的順序容器,且該
    的頭像 發(fā)表于 07-19 11:07 ?913次閱讀

    鴻蒙語言基礎ohos.util.ArrayList 線性容器ArrayList

    ArrayList是一種線性數(shù)據(jù)結構,底層基于數(shù)組實現(xiàn)。ArrayList會根據(jù)實際需要動態(tài)調整容量,每次擴容增加50%。
    的頭像 發(fā)表于 07-10 09:37 ?160次閱讀
    <b class='flag-5'>鴻蒙語言</b>基礎<b class='flag-5'>類</b><b class='flag-5'>庫</b>:<b class='flag-5'>ohos.util</b>.ArrayList <b class='flag-5'>線性</b><b class='flag-5'>容器</b>ArrayList

    鴻蒙語言基礎ohos.util.Deque 線性容器Deque

    Deque(double ended queue)根據(jù)循環(huán)隊列的數(shù)據(jù)結構實現(xiàn),符合先進先出以及先進后出的特點,支持兩端的元素插入和移除。Deque會根據(jù)實際需要動態(tài)調整容量,每次進行兩倍擴容。
    的頭像 發(fā)表于 07-10 09:19 ?189次閱讀
    <b class='flag-5'>鴻蒙語言</b>基礎<b class='flag-5'>類</b><b class='flag-5'>庫</b>:<b class='flag-5'>ohos.util</b>.Deque <b class='flag-5'>線性</b><b class='flag-5'>容器</b>Deque

    鴻蒙語言基礎ohos.util.HashMap 非線性容器HashMap

    HashMap底層使用數(shù)組+鏈表+紅黑樹的方式實現(xiàn),查詢、插入和刪除的效率都很高。HashMap存儲內容基于key-value的鍵值對映射,不能有重復的key,且一個key只能對應一個value。
    的頭像 發(fā)表于 07-10 16:31 ?324次閱讀
    <b class='flag-5'>鴻蒙語言</b>基礎<b class='flag-5'>類</b><b class='flag-5'>庫</b>:<b class='flag-5'>ohos.util</b>.HashMap 非<b class='flag-5'>線性</b><b class='flag-5'>容器</b>HashMap

    鴻蒙語言基礎ohos.util.TreeSet 非線性容器TreeSet

    TreeSet基于[TreeMap]實現(xiàn),在TreeSet中,只對value對象進行處理。TreeSet可用于存儲一系列值的集合,元素中value唯一且有序。
    的頭像 發(fā)表于 07-11 16:25 ?272次閱讀
    <b class='flag-5'>鴻蒙語言</b>基礎<b class='flag-5'>類</b><b class='flag-5'>庫</b>:<b class='flag-5'>ohos.util</b>.TreeSet 非<b class='flag-5'>線性</b><b class='flag-5'>容器</b>TreeSet