伦伦影院久久影视,天天操天天干天天射,ririsao久久精品一区 ,一本大道香蕉大久在红桃,999久久久免费精品国产色夜,色悠悠久久综合88,亚洲国产精品久久无套麻豆,亚洲香蕉毛片久久网站,一本一道久久综合狠狠老

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

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

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

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

福州市凌睿智捷電子有限公司 ? 2025-02-10 18:08 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1、程序簡(jiǎn)介

該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)的線程處理:Sempahore。

本案例完成如下工作:

(1)無名信號(hào)量使用方法

定義1個(gè)無名信號(hào)量,1個(gè)供無名信號(hào)量管理的公共資源變量;

創(chuàng)建5個(gè)線程,每個(gè)線程做5次for循環(huán),for循環(huán)的內(nèi)容是獲取無名信號(hào)量,并修改公共資源變量;

(2)有名信號(hào)量使用方法

定義1個(gè)有名信號(hào)量,1個(gè)供有名信號(hào)量管理的公共資源變量;

創(chuàng)建1個(gè)線程A,通過Open獲取信號(hào)量,做5次for循環(huán),for循環(huán)的內(nèi)容是通過Wait獲取有名信號(hào)量,如果獲取成功則修改公共資源變量(即累加1),最后釋放信號(hào)量;

創(chuàng)建1個(gè)線程B,通過Open獲取信號(hào)量,做5次for循環(huán),for循環(huán)的內(nèi)容是通過TryWait獲取有名信號(hào)量,如果獲取成功則修改公共資源變量(即累加10),最后釋放信號(hào)量;

創(chuàng)建1個(gè)線程C,通過Open獲取信號(hào)量,做5次for循環(huán),for循環(huán)的內(nèi)容是通過TimedWait獲取有名信號(hào)量,如果獲取成功則修改公共資源變量(即累加100),最后釋放信號(hào)量;

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

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

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

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

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

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

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

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

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

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

2.2、Semaphore頭文件

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

可在源代碼中添加如下:

#include

OpenHarmony信號(hào)量根據(jù)種類可以分為有名信號(hào)量和無名信號(hào)量,所以命令空間如下:

(1)無名信號(hào)量命名空間

OHOS::Semaphore

(2)有名信號(hào)量命名空間

OHOS::NamedSemaphore

2.3、OHOS::Samaphore接口說明

Semaphore為無名信號(hào)量。

2.3.1、Samaphore

構(gòu)造函數(shù), 構(gòu)造一個(gè)Samaphore對(duì)象。

Semaphore(int value = 1);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
valueint信號(hào)量當(dāng)前資源數(shù)量

2.3.2、~Semaphore

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

~Semaphore();

2.3.3、Wait

等待/獲取信號(hào)量(即信號(hào)量 -1)。

void Wait();

2.3.4、Post

釋放信號(hào)量(即信號(hào)量 +1)。

void Post();

2.4、OHOS::NamedSemaphore接口說明

NamedSemaphore為有名信號(hào)量。

2.4.1、NamedSemaphore

構(gòu)造函數(shù), 構(gòu)造NamedSemaphore對(duì)象。

NamedSemaphore(size_t size)NamedSemaphore(const std::string& name, size_t size)

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
namestd::string信號(hào)量名稱
sizesize_t信號(hào)量有效資源數(shù)量

2.4.2、~NamedSemaphore

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

~NamedSemaphore();

2.4.3、Create

創(chuàng)建并初始化有名信號(hào)量。

bool Create();

返回值說明:

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

2.4.4、Unlink

將有名信號(hào)量文件從系統(tǒng)中刪除。

bool Unlink();

返回值說明:

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

2.4.5、Open

打開一個(gè)已經(jīng)創(chuàng)建的有名信號(hào)量文件。

bool Open();

返回值說明:

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

2.4.6、Close

關(guān)閉有名信號(hào)量。

bool Close();

返回值說明:

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

2.4.7、Wait

等待/獲取信號(hào)量(信號(hào)量 -1)。

bool Wait();

返回值說明:

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

2.4.8、TryWait

等待/獲取信號(hào)量(信號(hào)量 -1)的接口;非阻塞版。

bool TryWait();

返回值說明:

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

2.4.9、TimedWait

等待/獲取信號(hào)量(信號(hào)量 -1);指定阻塞時(shí)間版。

bool TimedWait(const struct timespec& ts);

參數(shù)說明:

參數(shù)名稱類型參數(shù)說明
tsstruct timespec絕對(duì)時(shí)間。注意:ts是utc時(shí)間,不是相對(duì)時(shí)間。

返回值說明:

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

2.4.10、Post

釋放信號(hào)量(信號(hào)量 +1)。

bool Post();

返回值說明:

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

2.4.10、GetValue

獲取信號(hào)的值。

int GetValue() const;

返回值說明:

類型返回值說明
int返回當(dāng)前信號(hào)量的值

3、程序解析

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

在//vendor/lockzhiner/rk3568/samples/BUILD.gn文件添加一行編譯引導(dǎo)語句。

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

"a24_utils_semaphore:utils_semaphore",該行語句表示引入?yún)⑴c編譯。

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

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

a24_utils_semaphore├── utils_name_semaphore.cpp # 有名信號(hào)量案例├── utils_noname_semaphore.cpp # 無名信號(hào)量案例├── BUILD.gn # GN文件

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

編輯BUILD.gn文件。

添加2個(gè)可執(zhí)行程序,分別是:

utils_noname_semaphore:無名信號(hào)量使用案例

utils_name_semaphore:有名信號(hào)量使用案例

import("http://build/ohos.gni")
ohos_executable("utils_noname_semaphore") { sources = [ "utils_noname_semaphore.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}
ohos_executable("utils_name_semaphore") { sources = [ "utils_name_semaphore.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}
group("utils_semaphore") { deps = [ ":utils_noname_semaphore", ":utils_name_semaphore", ]}

注意:

(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、無名信號(hào)量使用案例

3.4.1、添加信號(hào)量頭文件

#include

3.4.2、創(chuàng)建無名信號(hào)量以及公共資源變量

static int m_count = 0; // 公共資源變量static OHOS::Semaphore m_sem(1); // 無名信號(hào)量

3.4.3、創(chuàng)建線程池

OHOS::ThreadPoolthreads("noname_semaphore_threads");

3.4.4、設(shè)置線程池

OHOS::ThreadPool threads("noname_semaphore_threads");

3.4.5、啟動(dòng)線程

for (int i = 0; i < threads_start; i++) { string str_name = "thread_" + to_string(i); auto task = std::bind(func, str_name); threads.AddTask(task); sleep(1);}

3.4.6、編寫子線程代碼

循環(huán)5次,每次循環(huán)調(diào)用信號(hào)量Wait()等待獲取信號(hào)量。如果獲取信號(hào)量后,將公共資源變量累加,調(diào)用信號(hào)量Post()釋放信號(hào)量。

void func(const string &name){ for (int i = 0; i < 5; i++) { cout << name << ": Sema Wait..." << endl; m_sem.Wait(); cout << name << ": Sema Wait Successful" << endl; m_count += 1; m_sem.Post(); cout << name << ": Sema Post" << endl; sleep(1); }}

3.5、有名信號(hào)量使用案例

3.5.1、添加信號(hào)量頭文件

#include

3.5.2、創(chuàng)建有名信號(hào)量

首先定義有名信號(hào)量,然后通過Create()創(chuàng)建全局有名信號(hào)量。

int main(int argc, char **argv){ OHOS::NamedSemaphore sem(STRING_NAME_SEMAPHORE, 1); ...... if (!sem.Create()) { cout << "NamedSemaphore.Create() failed\n"; return -1; } ......}

3.5.3、創(chuàng)建線程池

通過OHOS::ThreadPool定義線程池,調(diào)用SetMaxTaskNum()設(shè)置線程池最大線程數(shù),并調(diào)用Start()設(shè)置當(dāng)前啟動(dòng)多少個(gè)線程。

int main(int argc, char **argv){ OHOS::ThreadPool threads("name_semaphore_threads"); int threads_start = 3; ...... threads.SetMaxTaskNum(128); threads.Start(threads_start); ......}

3.5.4、啟動(dòng)子線程A、B和C

int main(int argc, char **argv){ ...... // 啟動(dòng)線程A str_name = "thread_a"; auto task_a = std::bind(funcA, str_name); threads.AddTask(task_a); // 啟動(dòng)線程B str_name = "thread_b"; auto task_b = std::bind(funcB, str_name); threads.AddTask(task_b);
// 啟動(dòng)線程A str_name = "thread_c"; auto task_c = std::bind(funcC, str_name); threads.AddTask(task_c); threads.Stop(); cout << "threads stop" << endl; return 0;}

3.5.5、編寫子線程A

首先定義有名信號(hào)量,信號(hào)量數(shù)目可以隨意設(shè)置。

其次,通過Open()打開有名信號(hào)量,可以與main()的有名信號(hào)量共享同一個(gè)信號(hào)量。

最后,通過Wait()和Post()來獲取釋放信號(hào)量。

static void funcA(const string &name){ OHOS::NamedSemaphore sem(STRING_NAME_SEMAPHORE, 1);
cout << get_curtime() << ", " << name << ": start\n";
// 打開一個(gè)已經(jīng)創(chuàng)建的有名信號(hào)量文件 if (!sem.Open()) { cout << get_curtime() << ", " << name << ": sema open failed" << endl; return; } for (int i = 0; i < 5; i++) { cout << get_curtime() << ", " << name << ": sema wait..." << endl; sem.Wait(); cout << get_curtime() << ", " << name << ": sema wait success" << endl; m_count += 1; usleep(1000 * 1000 * 1); cout << get_curtime() << ", " << name << ": sema count = " << m_count << endl; sem.Post(); cout << get_curtime() << ", " << name << ": sema post and sleep 1 sec" << endl; sleep(1); }
cout << get_curtime() << ", " << name << ": end" << endl;}

3.5.6、編寫子線程B

首先定義有名信號(hào)量,信號(hào)量數(shù)目可以隨意設(shè)置。

其次,通過Open()打開有名信號(hào)量,可以與main()的有名信號(hào)量共享同一個(gè)信號(hào)量。

最后,通過TryWait()和Post()來獲取釋放信號(hào)量。

static void funcB(const string &name){ OHOS::NamedSemaphore sem(STRING_NAME_SEMAPHORE, 1);
cout << get_curtime() << ", " << name << ": start\n"; // 打開一個(gè)已經(jīng)創(chuàng)建的有名信號(hào)量文件 if (!sem.Open()) { cout << get_curtime() << ", " << name << ": sema open failed" << endl; return; }
for (int i = 0; i < 5; i++) { cout << get_curtime() << ", " << name << ": sema trywait..." << endl; if (sem.TryWait()) { cout << get_curtime() << ", " << name << ": sema trywait success" << endl; m_count += 10; usleep(1000 * 1000 * 1); cout << get_curtime() << ", " << name << ": sema count = " << m_count << endl; sem.Post(); cout << get_curtime() << ", " << name << ": sema post and sleep 1 sec" << endl; } else { cout << get_curtime() << ", " << name << ": sema tryWait failed and sleep 1 sec" << endl; } sleep(1); }
cout << get_curtime() << ", " << name << ": end" << endl;}

3.5.7、編寫子線程C

首先定義有名信號(hào)量,信號(hào)量數(shù)目可以隨意設(shè)置。

其次,通過Open()打開有名信號(hào)量,可以與main()的有名信號(hào)量共享同一個(gè)信號(hào)量。

最后,通過TimedWait()和Post()來獲取釋放信號(hào)量。

static void funcC(const string &name){ OHOS::NamedSemaphore sem(STRING_NAME_SEMAPHORE, 1); struct timespec ts;
cout << get_curtime() << ", " << name << ": start\n";
// 打開一個(gè)已經(jīng)創(chuàng)建的有名信號(hào)量文件 if (!sem.Open()) { cout << get_curtime() << ", " << name << ": sema open failed" << endl; return; } for (int i = 0; i < 5; i++) { clock_gettime(CLOCK_REALTIME, &ts); // 超時(shí)等待時(shí)間,1秒 ts.tv_sec += 1; cout << get_curtime() << ", " << name << ": sema timedwait 1 sec..." << endl; if (sem.TimedWait(ts)) { cout << get_curtime() << ", " << name << ": sema timedwait success" << endl; m_count += 100; usleep(1000 * 100); cout << get_curtime() << ", " << name << ": sema count = " << m_count << endl; sem.Post(); cout << get_curtime() << ", " << name << ": sema post" << endl; } else { cout << get_curtime() << ", " << name << ": sema timedwait failed and sleep 1 sec" << endl; sleep(1); } }
cout << get_curtime() << ", " << name << ": end" << endl;
}

4、編譯步驟

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

hb build -f

將鏡像燒錄到開發(fā)板中。

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

5.1、無名信號(hào)量

運(yùn)行結(jié)果如下:

# utils_noname_semaphorethread_0: Sema Wait...thread_0: Sema Wait Successfulthread_0: Sema Postthread_1: Sema Wait...thread_1: Sema Wait Successfulthread_1: Sema Postthread_0: Sema Wait...thread_0: Sema Wait Successfulthread_0: Sema Postthread_2: Sema Wait...thread_2: Sema Wait Successfulthread_2: Sema Postthread_0: Sema Wait...thread_0: Sema Wait Successfulthread_0: Sema Postthread_1: Sema Wait...thread_1: Sema Wait Successfulthread_1: Sema Postthread_3: Sema Wait...thread_3: Sema Wait Successfulthread_3: Sema Postthread_2: Sema Wait...thread_0: Sema Wait Successfulthread_2: Sema Wait...thread_2: Sema Postthread_1: Sema Wait...thread_0: Sema Wait Successfulthread_0: Sema Postthread_1: Sema Wait Successfulthread_1: Sema Postthread_4: Sema Wait...thread_4: Sema Wait Successfulthread_4: Sema Postthread_3: Sema Wait...thread_3: Sema Wait Successfulthread_3: Sema Postthread_2: Sema Wait...thread_2: Sema Wait Successfulthread_2: Sema Postthread_0: Sema Wait...thread_0: Sema Wait Successfulthread_0: Sema Postthread_1: Sema Wait...thread_1: Sema Wait Successfulthread_1: Sema Postthread_4: Sema Wait...thread_4: Sema Wait Successfulthread_4: Sema Postthread_3: Sema Wait...thread_3: Sema Wait Successfulthread_3: Sema Postthread_2: Sema Wait...thread_2: Sema Wait Successfulthread_2: Sema Postthread_1: Sema Wait...thread_1: Sema Wait Successfulthread_1: Sema Postthread_4: Sema Wait...thread_4: Sema Wait Successfulthread_4: Sema Postthread_3: Sema Wait...thread_3: Sema Wait Successfulthread_3: Sema Postthread_2: Sema Wait...thread_2: Sema Wait Successfulthread_2: Sema Postthread_4: Sema Wait...thread_4: Sema Wait Successfulthread_4: Sema Postthread_3: Sema Wait...thread_3: Sema Wait Successfulthread_3: Sema Postthread_4: Sema Wait...thread_4: Sema Wait Successfulthread_4: Sema Postthreads stop#

5.2、有名信號(hào)量

運(yùn)行結(jié)果如下:

# utils_name_semaphore2017-8-5 1924, thread_a: start2017-8-5 19:43:24, thread_b: start2017-8-5 19:43:24, thread_c: start2017-8-5 19:43:24, thread_a: sema wait...2017-8-5 19:43:24, thread_a: sema wait success2017-8-5 19:43:24, thread_b: sema trywait...2017-8-5 19:43:24, thread_b: sema tryWait failed and sleep 1 sec2017-8-5 19:43:24, thread_c: sema timedwait 1 sec...2017-8-5 19:43:25, thread_a: sema count = 12017-8-5 19:43:25, thread_c: sema timedwait failed and sleep 1 sec2017-8-5 19:43:25, thread_a: sema post and sleep 1 sec2017-8-5 19:43:25, thread_b: sema trywait...2017-8-5 19:43:25, thread_b: sema trywait success2017-8-5 19:43:26, thread_a: sema wait...2017-8-5 19:43:26, thread_c: sema timedwait 1 sec...2017-8-5 19:43:26, thread_b: sema count = 112017-8-5 19:43:26, thread_b: sema post and sleep 1 sec2017-8-5 19:43:26, thread_a: sema wait success2017-8-5 19:43:27, thread_c: sema timedwait failed and sleep 1 sec2017-8-5 19:43:27, thread_b: sema trywait...2017-8-5 19:43:27, thread_b: sema tryWait failed and sleep 1 sec2017-8-5 19:43:27, thread_a: sema count = 122017-8-5 19:43:27, thread_a: sema post and sleep 1 sec2017-8-5 19:43:28, thread_c: sema timedwait 1 sec...2017-8-5 19:43:28, thread_c: sema timedwait success2017-8-5 19:43:28, thread_b: sema trywait...2017-8-5 19:43:28, thread_a: sema wait...2017-8-5 19:43:28, thread_b: sema tryWait failed and sleep 1 sec2017-8-5 19:43:28, thread_c: sema count = 1122017-8-5 19:43:28, thread_c: sema post2017-8-5 19:43:28, thread_c: sema timedwait 1 sec...2017-8-5 19:43:28, thread_a: sema wait success2017-8-5 19:43:29, thread_b: sema trywait...2017-8-5 19:43:29, thread_b: sema tryWait failed and sleep 1 sec2017-8-5 19:43:29, thread_c: sema timedwait failed and sleep 1 sec2017-8-5 19:43:29, thread_a: sema count = 1132017-8-5 19:43:29, thread_a: sema post and sleep 1 sec2017-8-5 19:43:30, thread_b: sema close2017-8-5 19:43:30, thread_c: sema timedwait 1 sec...2017-8-5 19:43:30, thread_c: sema timedwait success2017-8-5 19:43:30, thread_a: sema wait...2017-8-5 19:43:31, thread_c: sema count = 2132017-8-5 19:43:31, thread_c: sema post2017-8-5 19:43:31, thread_c: sema close2017-8-5 19:43:31, thread_a: sema wait success2017-8-5 19:43:32, thread_a: sema count = 2142017-8-5 19:43:32, thread_a: sema post and sleep 1 sec2017-8-5 19:43:33, thread_a: sema wait...2017-8-5 19:43:33, thread_a: sema wait success2017-8-5 19:43:34, thread_a: sema count = 2152017-8-5 19:43:34, thread_a: sema post and sleep 1 sec2017-8-5 19:43:35, thread_a: sema closethreads stop#

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

    關(guān)注

    0

    文章

    696

    瀏覽量

    35251
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    510

    瀏覽量

    20862
  • OpenHarmony
    +關(guān)注

    關(guān)注

    33

    文章

    3966

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    keil實(shí)現(xiàn)cc++混合編程

    起因項(xiàng)目中使用到一個(gè)開源的模擬IIC的庫(kù),封裝的比較好,但是是使用c++寫的。于是將其移植到自己的項(xiàng)目中,主要有以下三步操作: 在工程選項(xiàng)中 C/C++中去掉勾選
    發(fā)表于 01-26 08:58

    #OpenHarmony 系統(tǒng)概述

    OpenHarmony
    視美泰
    發(fā)布于 :2026年01月16日 09:39:20

    C語言與C++的區(qū)別及聯(lián)系

    并沒有錯(cuò)。 C++一開始被本賈尼·斯特勞斯特盧普(Bjarne Stroustrup)發(fā)明時(shí),起初被稱為“C with Classes”,即「帶C」。 很明顯,它是在
    發(fā)表于 12-24 07:23

    CC++之間的聯(lián)系

    控制能力,這一點(diǎn)與C語言相似,使得它們?cè)?b class='flag-5'>系統(tǒng)編程、嵌入式系統(tǒng)等領(lǐng)域都得到廣泛應(yīng)用。 3、發(fā)展歷程: C++正是在C語言的基礎(chǔ)上逐步發(fā)展起
    發(fā)表于 12-11 06:51

    C語言和C++之間的區(qū)別是什么

    (inheritance)、多態(tài)(polymorphism)等面向?qū)ο缶幊谈拍睢3绦騿T可以通過定義來創(chuàng)建對(duì)象,并利用的實(shí)例進(jìn)行操作。 2、類型系統(tǒng)與安全性: C++具有更為嚴(yán)格
    發(fā)表于 12-11 06:23

    庫(kù)標(biāo)準(zhǔn)C庫(kù)的區(qū)別

    因?yàn)獒槍?duì)Arm的嵌入式系統(tǒng),通常存儲(chǔ)(代碼)資源相對(duì)較小,為了使其能用上標(biāo)準(zhǔn)函數(shù),工程師就針對(duì)Arm嵌入式系統(tǒng),對(duì)標(biāo)準(zhǔn)C
    發(fā)表于 12-09 07:49

    OpenHarmony TSC 2025年度技術(shù)課題發(fā)布(截至10月)

    、學(xué)者們揭榜課題、參與分解課題,共同推動(dòng)開源鴻蒙終端操作系統(tǒng)的技術(shù)突破與生態(tài)繁榮。詳見下表: 挑戰(zhàn)方向 挑戰(zhàn)課題 挑戰(zhàn)方向1:以用戶為中心、場(chǎng)景感知的應(yīng)用軟件新形態(tài) 面向OpenHarmony平臺(tái)的C/
    的頭像 發(fā)表于 11-05 19:12 ?1466次閱讀

    技能+1!如何在樹莓派上使用C++控制GPIO?

    和PiGPIO等庫(kù)C++可用于編程控制樹莓派的GPIO引腳。它提供了更好的性能和控制能力,非常適合對(duì)速度和精度要求較高的硬件項(xiàng)目。在樹莓派社區(qū)中,關(guān)于“Python
    的頭像 發(fā)表于 08-06 15:33 ?4425次閱讀
    技能+1!如何在樹莓派上使用<b class='flag-5'>C++</b>控制GPIO?

    C++ 與 Python:樹莓派上哪種語言更優(yōu)?

    Python是樹莓派上的首選編程語言,我們的大部分教程都使用它。然而,C++在物聯(lián)網(wǎng)項(xiàng)目中同樣廣受歡迎且功能強(qiáng)大。那么,在樹莓派項(xiàng)目中選擇哪種語言更合適呢?Python因其簡(jiǎn)潔性、豐富的庫(kù)和資源而被
    的頭像 發(fā)表于 07-24 15:32 ?1062次閱讀
    <b class='flag-5'>C++</b> 與 Python:樹莓派上哪種語言更優(yōu)?

    【重要通知】OpenHarmony主干平臺(tái)開發(fā)板選型提報(bào)倒計(jì)時(shí)(參考工具發(fā)布)

    各位伙伴好: 鑒于當(dāng)前開源鴻蒙標(biāo)準(zhǔn)系統(tǒng)的主線驗(yàn)證平臺(tái)(RK3568)在性能上已難以滿足未來幾年的發(fā)展需求。為確保系統(tǒng)持續(xù)演進(jìn),現(xiàn)啟動(dòng)下一代主力驗(yàn)證平臺(tái)的規(guī)劃工作。 經(jīng)過初步調(diào)研,我們篩選出四個(gè)候選
    發(fā)表于 07-24 09:17

    OpenHarmony 2025年度技術(shù)課題發(fā)布

    課題共計(jì)6道。熱切期待各界的專家、學(xué)者們揭榜課題、參與分解課題,共同推動(dòng)OpenHarmony終端操作系統(tǒng)的技術(shù)突破與生態(tài)繁榮。詳見下表: 挑戰(zhàn)方向 挑戰(zhàn)課題 挑戰(zhàn)方向1:以用戶為中心、場(chǎng)景感知的應(yīng)用軟件新形態(tài) 面向OpenHarmon
    的頭像 發(fā)表于 07-23 20:57 ?869次閱讀

    基于LockAI視覺識(shí)別模塊:C++目標(biāo)檢測(cè)

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識(shí)別模塊,通過C++語言做的目標(biāo)檢測(cè)實(shí)驗(yàn)。本文檔展示了如何使用lockzhiner_vision_module::PaddleDet進(jìn)行目標(biāo)檢測(cè),并通過lockzhiner_vision_module::Visualiz
    的頭像 發(fā)表于 06-06 13:56 ?976次閱讀
    基于LockAI視覺識(shí)別模塊:<b class='flag-5'>C++</b>目標(biāo)檢測(cè)

    貢獻(xiàn) OpenHarmony 庫(kù)關(guān)鍵配置

    # 貢獻(xiàn) OpenHarmony 庫(kù)關(guān)鍵配置 #自研框架#ArkUI-X#三方框架#OpenHarmony#HarmonyOS ## 創(chuàng)建第三方庫(kù) - 打開 DevEco Stud
    發(fā)表于 05-28 13:46

    PCB標(biāo)準(zhǔn)封裝庫(kù)文件

    PCB標(biāo)準(zhǔn)封裝庫(kù)文件
    發(fā)表于 05-22 17:43 ?10次下載

    一文帶你了解KaihongOS標(biāo)準(zhǔn)系統(tǒng)的技術(shù)架構(gòu)、子系統(tǒng)系統(tǒng)應(yīng)用、典型特性以及支持的設(shè)備類型

    分布式軟總線子系統(tǒng) 2.10.1 子系統(tǒng)概述 KaihongOS標(biāo)準(zhǔn)系統(tǒng)軟件是基于OpenHarmony開發(fā)的新時(shí)代萬物互聯(lián)的操作系統(tǒng)
    發(fā)表于 04-23 07:17