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

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

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

基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫案例:SafeMap

福州市凌睿智捷電子有限公司 ? 2024-08-30 12:42 ? 次閱讀

1、程序簡介

該程序是基于OpenHarmonyC++公共基礎(chǔ)類庫的安全關(guān)聯(lián)容器:SafeMap。

OpenHarmony提供了一個線程安全的map實(shí)現(xiàn)。SafeMap在STL map基礎(chǔ)上封裝互斥鎖,以確保對map的操作安全。

本案例主要完成如下工作:

創(chuàng)建1個子線程,負(fù)責(zé)每秒調(diào)用EnsureInsert()插入元素;

創(chuàng)建1個子線程,負(fù)責(zé)每秒調(diào)用Insert()插入元素;

創(chuàng)建1個子線程,負(fù)責(zé)每秒調(diào)用Erase()刪除元素;

創(chuàng)建1個子線程,負(fù)責(zé)每秒調(diào)用FindOldAndSetNew()替換元素的值;

主線程等待上述線程結(jié)束,Iterate()和Find()查看所有元素;

主線程等待上述線程結(jié)束,清空SafeMap,并調(diào)用IsEmpty()查看是否確實(shí)是空。

2、基礎(chǔ)知識

C++公共基礎(chǔ)類庫為標(biāo)準(zhǔn)系統(tǒng)提供了一些常用的C++開發(fā)工具類,包括:

文件、路徑、字符串相關(guān)操作的能力增強(qiáng)接口

讀寫鎖、信號量、定時器、線程增強(qiáng)及線程池等接口

安全數(shù)據(jù)容器、數(shù)據(jù)序列化等接口

各子系統(tǒng)的錯誤碼相關(guān)定義

2.1、添加C++公共基礎(chǔ)類庫依賴

修改需調(diào)用模塊的BUILD.gn,在external_deps或deps中添加如下:

ohos_shared_library("xxxxx") { ... external_deps = [ ... # 動態(tài)庫依賴(可選) "c_utils:utils", # 靜態(tài)庫依賴(可選) "c_utils:utilsbase", # Rust動態(tài)庫依賴(可選) "c_utils:utils_rust", ] ...}

一般而言,我們只需要填寫"c_utils:utils"即可。

2.2、SafeMap頭文件

C++公共基礎(chǔ)類庫的safemap頭文件在://commonlibrary/c_utils/base/include/safe_map.h

可在源代碼中添加如下:

#include

2.3、OHOS::SafeMap接口說明

2.3.1、SafeMap

構(gòu)造函數(shù)。

SafeMap();SafeMap(const SafeMap& rhs);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
rhsSafeMap復(fù)制SafeMap的類對象

2.3.2、~SafeMap

析構(gòu)函數(shù)。

~SafeMap();

2.3.3、Clear

刪除map中存儲的所有鍵值對。

void Clear();

2.3.4、EnsureInsert

在map中插入元素。

void EnsureInsert(const K& key, const V& value);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
keyK需要插入元素的關(guān)鍵字
valueV需要插入元素的值

2.3.5、Erase

刪除map中鍵為key的鍵值對。

void Erase(const K& key);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
keyK需要刪除元素的關(guān)鍵字

2.3.6、Find

在map中查找元素。

bool Find(const K& key, V& value);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
keyK需要查找元素的關(guān)鍵字
valueV需要查找元素的值

返回值說明:

類型返回值說明
booltrue表示成功,false表示失敗

2.3.7、FindOldAndSetNew

在map中查找元素并將key對應(yīng)的oldValue替換為newValue。

boolFindOldAndSetNew(constK&key,V&oldValue,constV&newValue);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
keyK需要替換元素的關(guān)鍵字
oldValueV需要替換元素的原始值
newValueV需要替換元素的新值

返回值說明:

類型返回值說明
booltrue表示成功,false表示失敗

2.3.8、Insert

在map中插入新元素。

bool Insert(const K& key, const V& value);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
keyK需要插入元素的關(guān)鍵字
valueV需要插入元素的原始值

返回值說明:

類型返回值說明
booltrue表示成功,false表示失敗

2.3.9、IsEmpty

判斷map是否為空。

bool IsEmpty();

返回值說明:

類型返回值說明
booltrue表示空,false表示非空

2.3.10、Iterate

遍歷map中的元素。

bool Iterate(const SafeMapCallBack& callback);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
callbackSafeMapCallBack遍歷執(zhí)行函數(shù)

2.3.11、operator=

SafeMap賦值。

SafeMap& operator=(const SafeMap& rhs);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
rhsSafeMap&被賦值的SafeMap類對象

返回值說明:

類型返回值說明
SafeMap賦值的SafeMap類對象

2.3.12、operator[]

SafeMap索引

V& operator[](const K& key);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
keyK&元素的關(guān)鍵字

返回值說明:

類型返回值說明
V&返回元素的值

2.3.13、Size

獲取map的size大小。

int Size();

返回值說明:

類型返回值說明
intmap的size大小

3、程序解析

3.1、創(chuàng)建編譯引導(dǎo)

在上一級目錄BUILD.gn文件添加一行編譯引導(dǎo)語句。

import("http://build/ohos.gni")
group("samples") { deps = [ "a26_utils_safemap:utils_safemap", # 添加該行 ]}

"a26_utils_safemap:utils_safemap",該行語句表示引入 參與編譯。

3.2、創(chuàng)建編譯項(xiàng)目

創(chuàng)建a26_utils_safemap目錄,并添加如下文件:

a26_utils_safemap├── utils_safemap_sample.cpp # .cpp源代碼├── BUILD.gn # GN文件

3.3、創(chuàng)建BUILD.gn

編輯BUILD.gn文件。

import("http://build/ohos.gni")ohos_executable("utils_safemap") { sources = [ "utils_safemap_sample.cpp" ] include_dirs = [ "http://commonlibrary/c_utils/base/include", "http://commonlibrary/c_utils/base:utils", "http://third_party/googletest:gtest_main", "http://third_party/googletest/googletest/include" ] external_deps = [ "c_utils:utils" ] part_name = "product_rk3568" install_enable = true}

注意:

(1)BUILD.gn中所有的TAB鍵必須轉(zhuǎn)化為空格,否則會報(bào)錯。如果自己不知道如何規(guī)范化,可以:

# 安裝gn工具sudo apt-get install ninja-buildsudo apt install generate-ninja# 規(guī)范化BUILD.gngn format BUILD.gn

3.4、創(chuàng)建源代碼

3.4.1、創(chuàng)建SafeMap

#include // SafeMap的頭文件
// 定義SafeMap變量static OHOS::SafeMap m_safemap;

3.4.2、創(chuàng)建線程池并設(shè)置

int main(int argc, char **argv){ OHOS::ThreadPool threads("name_rwlock_threads"); string str_name; ...... threads.SetMaxTaskNum(128); threads.Start(4); ......}

3.4.3、啟動4個子線程,并等待結(jié)束

調(diào)用AddTask()添加子線程,并調(diào)用Stop()等待所有子進(jìn)程結(jié)束。

// 開啟子線程,使用EnsureInsert插入元素str_name = "Thread_EnsureInsert";auto task_ensure_insert = std::bind(map_ensure_insert, str_name);threads.AddTask(task_ensure_insert);
// 開啟子線程,使用Insert插入元素str_name = "Thread_Insert";auto task_insert = std::bind(map_insert, str_name);threads.AddTask(task_insert);
// 開啟子線程,使用erase刪除元素str_name = "Thread_Erase";auto task_erase = std::bind(map_erase, str_name);threads.AddTask(task_erase);
// 開啟子線程,使用FindOldAndSetNew替換元素的值str_name = "Thread_FindOldAndSetNew";auto task_findold_and_setnew = std::bind(map_findold_and_setnew, str_name);threads.AddTask(task_findold_and_setnew);
// 設(shè)置結(jié)束,并等待結(jié)束threads.Stop();cout << "Threads Stop" << endl;

3.4.4、編寫SafeMap.EnsureInsert()插入元素

void map_ensure_insert(const string& name){ int key = 0; string value = ""; for (int i = 0; i < (sizeof(m_map1_insert) / sizeof(struct MapInfo)); i++) { key = m_map1_insert[i].key; value = m_map1_insert[i].str; m_safemap.EnsureInsert(key, value); cout << name << ": insert successful and key = " << key << " and value = " << value << endl; sleep(1); }}

3.4.5、編寫SafeMap.Insert()插入元素

void map_insert(const string& name){ int key = 0; string value = ""; for (int i = 0; i < (sizeof(m_map2_insert) / sizeof(struct MapInfo)); i++) { key = m_map2_insert[i].key; value = m_map2_insert[i].str; if (m_safemap.Insert(key, value) == false) { cout << name << ": insert failed and key = " << to_string(key) << " and value = " << value << endl; } else { cout << name << ": insert successful and key = " << to_string(key) << " and value = " << value << endl; } sleep(1); }}

3.4.6、編寫SafeMap.Erase()刪除元素

void map_erase(const string& name){ int key = 0; string value = ""; for (int i = 0; i < (sizeof(m_map2_insert) / sizeof(struct MapInfo)); i++) { key = m_map2_insert[i].key; m_safemap.Erase(key); cout << name << ": Erase successful and key = " << to_string(key) << endl; sleep(1); }}

3.4.7、編寫SafeMap.FindOldAndSetNew()替換元素的值

void map_findold_and_setnew(const string& name){ int key = 0; string old_value = ""; string new_value = ""; for (int i = 0; i < (sizeof(m_map1_insert) / sizeof(struct MapInfo)); i++) { key = m_map1_reset[i].key; old_value = ""; new_value = m_map1_reset[i].str; if (m_safemap.FindOldAndSetNew(key, old_value, new_value) == false) { cout << name << ": FindOldAndSetNew failed and key = " << to_string(key) << " and old_value = " << old_value << endl; } else { cout << name << ": FindOldAndSetNew successful and key = " << to_string(key) << " and old_value = " << old_value << " and new_value = " << new_value << endl; } sleep(1); }}

3.4.8、編寫枚舉所有元素

主要分為如下兩種方法:

(1)調(diào)用SafeMap.Iterate()

void map_iterate_print(const int key, string& value){ cout << "key = " << to_string(key) << ", value = " << value << endl;}
int main(int argc, char *argv[]){ ...... cout << "SafeMap Iterate: " << endl; m_safemap.Iterate(map_iterate_print); ......}

(2)調(diào)用SafeMap.Find()

void map_find_print(){ int key = 0; string value = ""; for (int i = 0; i < (sizeof(m_map1_insert) / sizeof(struct MapInfo)); i++) { key = m_map1_insert[i].key; value = ""; if (m_safemap.Find(key, value)) { cout << "key = " << to_string(key) << ", value = " << value << endl; } } for (int i = 0; i < (sizeof(m_map2_insert) / sizeof(struct MapInfo)); i++) { key = m_map2_insert[i].key; value = ""; if (m_safemap.Find(key, value)) { cout << "key = " << to_string(key) << ", value = " << value << endl; } }}

3.4.9、清空SafeMap

int main(int argc, char *argv[]){ ...... cout << "SafeMap Clear" << endl; m_safemap.Clear(); cout << "SafeMap IsEmpty: " << m_safemap.IsEmpty() << endl; ......}

4、編譯步驟

進(jìn)入OpenHarmony編譯環(huán)境,運(yùn)行命令:

hb build -f

5、運(yùn)行結(jié)果

# utils_safemapThread_EnsureInsert: insert successful and key = 1 and value = aaaThread_Erase: Erase successful and key = Thread_FindOldAndSetNew: FindOldAndSetNew successful and key = 1 and old_value = aaa and new_value = abc101Thread_Insert: insert successful and key = 101 and value = 111Thread_EnsureInsert: insert successful and key = Thread_FindOldAndSetNew: FindOldAndSetNew successful and key = 2 and old_value = bbb and new_value = bcdThread_Insert: insert successful and key = 102 and value = 2222 and value = bbb
Thread_Erase: Erase successful and key = 102Thread_EnsureInsert: insert successful and key = 3 and value = cccThread_FindOldAndSetNew: FindOldAndSetNew successful and key = 3 and old_value = ccc and new_value = cdeThread_Insert: insert successful and key = 103 and value = 333Thread_Erase: Erase successful and key = 103Thread_EnsureInsert: insert successful and key = 4 and value = dddThread_Insert: insert successful and key = 104Thread_FindOldAndSetNew and value = : FindOldAndSetNew successful and key = 4444 and old_value = ddd and new_value = def
Thread_Erase: Erase successful and key = 104Thread_EnsureInsert: insert successful and key = 5 and value = eeeThread_Insert: insert successful and key = 105 and value = 555Thread_FindOldAndSetNew: FindOldAndSetNew successful and key = 5 and old_value = eee and new_value = efgThread_Erase: Erase successful and key = 105Thread_EnsureInsert: insert successful and key = 6 and value = fffThread_FindOldAndSetNew: FindOldAndSetNew successful and key = 6 and old_value = fff and new_value = fghThread_Insert: insert successful and key = 106 and value = 666Thread_Erase: Erase successful and key = 106Thread_EnsureInsert: insert successful and key = 7 and value = gggThread_FindOldAndSetNew: FindOldAndSetNew successful and key = 7 and old_value = ggg and new_value = ghiThread_Erase: Erase successful and key = 107Thread_Insert: insert successful and key = 107 and value = 777Thread_EnsureInsert: insert successful and key = 8 and value = hhhThread_FindOldAndSetNew: FindOldAndSetNew successful and key = 8 and old_value = hhh and new_value = hijThread_Erase: Erase successful and key = 108Thread_Insert: insert successful and key = 108 and value = 888Thread_EnsureInsert: insert successful and key = 9 and value = iiiThread_FindOldAndSetNew: FindOldAndSetNew successful and key = 9 and old_value = iii and new_value = ijkThread_Erase: Erase successful and key = 109Thread_Insert: insert successful and key = 109 and value = 999Thread_EnsureInsert: insert successful and key = 10 and value = jjjThread_FindOldAndSetNew: FindOldAndSetNew successful and key = 10 and old_value = jjj and new_value = jklThread_Erase: Erase successful and key = 110Thread_Insert: insert successful and key = 110 and value = 000Threads StopSafeMap Iterate:key = 1, value = abckey = 2, value = bcdkey = 3, value = cdekey = 4, value = defkey = 5, value = efgkey = 6, value = fghkey = 7, value = ghikey = 8, value = hijkey = 9, value = ijkkey = 10, value = jklkey = 108, value = 888key = 109, value = 999key = 110, value = 000SafeMap Find:key = 1, value = abckey = 2, value = bcdkey = 3, value = cdekey = 4, value = defkey = 5, value = efgkey = 6, value = fghkey = 7, value = ghikey = 8, value = hijkey = 9, value = ijkkey = 10, value = jklkey = 108, value = 888key = 109, value = 999key = 110, value = 000SafeMap ClearSafeMap IsEmpty: 1#

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

    關(guān)注

    0

    文章

    49

    瀏覽量

    15449
  • Safe
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    7324
  • OpenHarmony
    +關(guān)注

    關(guān)注

    28

    文章

    3840

    瀏覽量

    18259
收藏 人收藏

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:ThreadPoll

    1、程序簡介 該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)的線程池處理:Thr
    發(fā)表于 08-12 11:42

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:Semaphore

    1、程序簡介 該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)的線程處理:Semp
    發(fā)表于 08-14 16:38

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:rwlock

    /samples/a25_utils_rwlock 2、基礎(chǔ)知識 C++公共基礎(chǔ)標(biāo)準(zhǔn)系統(tǒng)提供了一些常用的
    發(fā)表于 08-20 09:37

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:SafeMap

    1、程序簡介 該程序是基于OpenHarmonyC++公共基礎(chǔ)的安全關(guān)聯(lián)容器:SafeMap
    發(fā)表于 08-20 12:00

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:SafeQueue

    /a27_utils_safequeue 2、基礎(chǔ)知識 C++公共基礎(chǔ)標(biāo)準(zhǔn)系統(tǒng)提供了一些常用的C+
    發(fā)表于 08-21 10:56

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:SafeStack

    /a28_utils_safestack 2、基礎(chǔ)知識 C++公共基礎(chǔ)標(biāo)準(zhǔn)系統(tǒng)提供了一些常用的C+
    發(fā)表于 08-21 14:51

    OpenHarmony C++公共基礎(chǔ)應(yīng)用案例:Thread

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)的線程處理:Thread。該應(yīng)用案例已在
    的頭像 發(fā)表于 11-23 08:22 ?1238次閱讀
    <b class='flag-5'>OpenHarmony</b> <b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>應(yīng)用案例:Thread

    OpenHarmony C++公共基礎(chǔ)應(yīng)用案例:HelloWorld

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)的簡單案例:HelloWorld。該應(yīng)用案例已在
    的頭像 發(fā)表于 11-23 08:22 ?934次閱讀
    <b class='flag-5'>OpenHarmony</b> <b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>應(yīng)用案例:HelloWorld

    OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:HelloWorld

    1、程序簡介該程序是基于凌蒙派OpenHarmony-v3.2.1標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)的簡
    的頭像 發(fā)表于 08-13 08:23 ?811次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b><b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:HelloWorld

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:SafeBlockQueue

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)的讀寫鎖:SafeBlockQueue。線程安全阻塞隊(duì)列SafeBlock
    的頭像 發(fā)表于 08-30 12:41 ?545次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b>的<b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:SafeBlockQueue

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:SafeStack

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)的線程安全隊(duì)列:SafeQueue。線程安全隊(duì)列,是在dequeue的基礎(chǔ)
    的頭像 發(fā)表于 08-30 12:41 ?648次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b>的<b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:SafeStack

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:SafeQueue

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)的線程安全隊(duì)列:SafeQueue。線程安全隊(duì)列,是在dequeue的基礎(chǔ)
    的頭像 發(fā)表于 08-30 12:41 ?630次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b>的<b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:SafeQueue

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:rwlock

    1、程序簡介該程序是基于OpenHarmonyC++公共基礎(chǔ)的讀寫鎖:rwlock。本案例主要完成如下工作:創(chuàng)建3個讀線程,每個讀線程
    的頭像 發(fā)表于 08-30 12:42 ?618次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b>的<b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:rwlock

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:Semaphore

    1、程序簡介該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)的線程處理:Sempa
    的頭像 發(fā)表于 02-10 18:08 ?304次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b>的<b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:Semaphore

    基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)案例:ThreadPoll

    1、程序簡介該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)的線程池處理:Thre
    的頭像 發(fā)表于 02-10 18:09 ?313次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標(biāo)準(zhǔn)系統(tǒng)</b>的<b class='flag-5'>C++</b><b class='flag-5'>公共</b>基礎(chǔ)<b class='flag-5'>類</b><b class='flag-5'>庫</b>案例:ThreadPoll
    主站蜘蛛池模板: 三级色网站 | 天堂网最新版中文 | 唐人社电亚洲一区二区三区 | 最近2018中文字幕2019视频 | 黑人40厘米全进去xxxx猛交 | 一级a性色生活片毛片 | 欧美一区二区视频在线观看 | 天天干天天摸天天操 | 丁香综合在线 | 亚洲欧美高清 | 欧美成人免费夜夜黄啪啪 | 色多多视频官网 | 国产精品午夜寂寞视频 | 少妇被按摩| 久久精品高清 | 白嫩少妇激情无码 | 国产h视频在线观看高清 | 激情丁香六月 | 色狠狠网 | 狠狠色噜狠狠狠狠 | 在线视频 亚洲 | 国模欢欢炮交啪啪150 | 35pao强力 | 丁香在线| 欧美一区二区三区综合色视频 | 四虎久久影院 | 欧美成人午夜视频 | 国产小视频免费看 | 老色99久久九九精品尤物 | 四虎永久在线日韩精品观看 | h网站免费 | 国产精品久久久亚洲第一牛牛 | 久久国产成人精品国产成人亚洲 | 4438成人成人高清视频 | 丰满年轻岳欲乱中文字幕 | 久久综合狠狠综合久久 | 天天襙| 月夜免费观看高清在线完整 | 天堂免费在线视频 | 久久久久久久久综合影视网 | www.狠狠|