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

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

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

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

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

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

1、程序簡(jiǎn)介

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

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

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

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

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

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

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

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

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

2、基礎(chǔ)知識(shí)

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

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

讀寫(xiě)鎖、信號(hào)量、定時(shí)器、線程增強(qiáng)及線程池等接口

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

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

2.1、添加C++公共基礎(chǔ)類(lèi)庫(kù)依賴(lài)

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

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

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

2.2、SafeMap頭文件

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

可在源代碼中添加如下:

#include

2.3、OHOS::SafeMap接口說(shuō)明

2.3.1、SafeMap

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

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

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
rhsSafeMap復(fù)制SafeMap的類(lèi)對(duì)象

2.3.2、~SafeMap

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

~SafeMap();

2.3.3、Clear

刪除map中存儲(chǔ)的所有鍵值對(duì)。

void Clear();

2.3.4、EnsureInsert

在map中插入元素。

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

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
keyK需要插入元素的關(guān)鍵字
valueV需要插入元素的值

2.3.5、Erase

刪除map中鍵為key的鍵值對(duì)。

void Erase(const K& key);

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
keyK需要?jiǎng)h除元素的關(guān)鍵字

2.3.6、Find

在map中查找元素。

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

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
keyK需要查找元素的關(guān)鍵字
valueV需要查找元素的值

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
booltrue表示成功,false表示失敗

2.3.7、FindOldAndSetNew

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

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

參數(shù)說(shuō)明:

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

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
booltrue表示成功,false表示失敗

2.3.8、Insert

在map中插入新元素。

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

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
keyK需要插入元素的關(guān)鍵字
valueV需要插入元素的原始值

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
booltrue表示成功,false表示失敗

2.3.9、IsEmpty

判斷map是否為空。

bool IsEmpty();

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
booltrue表示空,false表示非空

2.3.10、Iterate

遍歷map中的元素。

bool Iterate(const SafeMapCallBack& callback);

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
callbackSafeMapCallBack遍歷執(zhí)行函數(shù)

2.3.11、operator=

SafeMap賦值。

SafeMap& operator=(const SafeMap& rhs);

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
rhsSafeMap&被賦值的SafeMap類(lèi)對(duì)象

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
SafeMap賦值的SafeMap類(lèi)對(duì)象

2.3.12、operator[]

SafeMap索引

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

參數(shù)說(shuō)明:

參數(shù)名稱(chēng)類(lèi)型參數(shù)說(shuō)明
keyK&元素的關(guān)鍵字

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
V&返回元素的值

2.3.13、Size

獲取map的size大小。

int Size();

返回值說(shuō)明:

類(lèi)型返回值說(shuō)明
intmap的size大小

3、程序解析

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

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

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

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

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)化為空格,否則會(huì)報(bào)錯(cuò)。如果自己不知道如何規(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、啟動(dòng)4個(gè)子線程,并等待結(jié)束

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

// 開(kāi)啟子線程,使用EnsureInsert插入元素str_name = "Thread_EnsureInsert";auto task_ensure_insert = std::bind(map_ensure_insert, str_name);threads.AddTask(task_ensure_insert);
// 開(kāi)啟子線程,使用Insert插入元素str_name = "Thread_Insert";auto task_insert = std::bind(map_insert, str_name);threads.AddTask(task_insert);
// 開(kāi)啟子線程,使用erase刪除元素str_name = "Thread_Erase";auto task_erase = std::bind(map_erase, str_name);threads.AddTask(task_erase);
// 開(kāi)啟子線程,使用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、編寫(xiě)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、編寫(xiě)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、編寫(xiě)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、編寫(xiě)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、編寫(xiě)枚舉所有元素

主要分為如下兩種方法:

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

    關(guān)注

    0

    文章

    49

    瀏覽量

    15405
  • Safe
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    7317
  • OpenHarmony
    +關(guān)注

    關(guān)注

    26

    文章

    3820

    瀏覽量

    18113
收藏 人收藏

    評(píng)論

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

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

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

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

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

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

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

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

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

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

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

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

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

    OpenHarmony C++公共基礎(chǔ)類(lèi)庫(kù)應(yīng)用案例:Thread

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

    OpenHarmony C++公共基礎(chǔ)類(lèi)庫(kù)應(yīng)用案例:HelloWorld

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

    OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)類(lèi)庫(kù)案例:HelloWorld

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

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

    1、程序簡(jiǎn)介該程序是基于OpenHarmonyC++公共基礎(chǔ)類(lèi)庫(kù)的讀寫(xiě)鎖:SafeBlockQueue。線程安全阻塞隊(duì)列SafeBlock
    的頭像 發(fā)表于 08-30 12:41 ?515次閱讀
    基于<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'>類(lèi)</b><b class='flag-5'>庫(kù)</b>案例:SafeBlockQueue

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

    1、程序簡(jiǎn)介該程序是基于OpenHarmonyC++公共基礎(chǔ)類(lèi)庫(kù)的線程安全隊(duì)列:SafeQueue。線程安全隊(duì)列,是在dequeue的基礎(chǔ)
    的頭像 發(fā)表于 08-30 12:41 ?616次閱讀
    基于<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'>類(lèi)</b><b class='flag-5'>庫(kù)</b>案例:SafeStack

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

    1、程序簡(jiǎn)介該程序是基于OpenHarmonyC++公共基礎(chǔ)類(lèi)庫(kù)的線程安全隊(duì)列:SafeQueue。線程安全隊(duì)列,是在dequeue的基礎(chǔ)
    的頭像 發(fā)表于 08-30 12:41 ?590次閱讀
    基于<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'>類(lèi)</b><b class='flag-5'>庫(kù)</b>案例:SafeQueue

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

    1、程序簡(jiǎn)介該程序是基于OpenHarmonyC++公共基礎(chǔ)類(lèi)庫(kù)的讀寫(xiě)鎖:rwlock。本案例主要完成如下工作:創(chuàng)建3個(gè)讀線程,每個(gè)讀線程
    的頭像 發(fā)表于 08-30 12:42 ?601次閱讀
    基于<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'>類(lèi)</b><b class='flag-5'>庫(kù)</b>案例:rwlock

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

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

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

    1、程序簡(jiǎn)介該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)C++公共基礎(chǔ)類(lèi)庫(kù)的線程池處理:Thre
    的頭像 發(fā)表于 02-10 18:09 ?281次閱讀
    基于<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'>類(lèi)</b><b class='flag-5'>庫(kù)</b>案例:ThreadPoll