亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 後端開發(fā) C++ Rust 線路安全性:與 C 的比較。

Rust 線路安全性:與 C 的比較。

Nov 19, 2024 am 11:54 AM

在這個POC(概念證明)中,我們將探索Rust語言如何處理競爭條件,並將其與C ,一種廣泛使用的語言,但競爭的安全保障較少。

Rust 線路安全性:與 C 的比較

執(zhí)行緒安全:從 C 到 Rust 的資料競爭

指數(shù)

    一、簡介
  • 2. 執(zhí)行緒
  • 3. C 語言的實現(xiàn)
    • 3.1.沒有針對競爭條件的保護的程式碼
    • 3.2.使用互斥體修復
  • 4. Rust 中的實現(xiàn)
    • 4.1.競爭條件問題
    • 4.2.互斥體和弧的解析
    • 4.3.互斥體對比讀寫鎖
  • 5. 結論
  • 6. 參考文獻

一、簡介

在計算中,

執(zhí)行緒用於將軟體任務分割為可以並發(fā)執(zhí)行的子任務。透過使用線程,我們獲得了處理時間並更好地利用機器的資源,但這種競爭帶來了挑戰(zhàn),例如競爭條件,這可能會產(chǎn)生數(shù)據(jù)的嚴重不一致。


2. 執(zhí)行緒

執(zhí)行緒是允許您同時處理任務的執(zhí)行單元。我們可以將執(zhí)行緒視為程式內獨立的執(zhí)行流,如下圖所示:

Rust Threads safety: Uma compara??o com C.

雖然執(zhí)行緒帶來了效能優(yōu)勢,但它們也帶來了風險,尤其是在存取共享資源時。

此外,執(zhí)行緒還可以用來實現(xiàn)並行性,即多個任務在不同的CPU核心上同時執(zhí)行。這使得程式能夠更好地利用可用的硬件,加快獨立任務的執(zhí)行速度。


3. C 語言的實現(xiàn)

讓我們在

C 中建立一個簡單的系統(tǒng):

    初始餘額為 1000。
  1. 一組可以是貸方或借方的交易。
  2. 使用執(zhí)行緒並行處理這些事務。
3.1.沒有針對競爭條件的保護的程式碼

int saldo = 1000; 

void creditar(int valor) {
    int tmp_saldo = saldo;

    sleep(1); // Delay simulado

    saldo += tmp_saldo + valor;
}

void debitar(int valor) {
    int temp = saldo;

    sleep(1); // Delay simulado

    if (temp >= valor) {
        saldo = temp - valor;
    }
}

void* processar_transacao(void* arg) {
    int valor = *(int*)arg;

    if (valor > 0) {
        creditar(valor);
    } else {
        debitar(abs(valor));
    }

    return NULL;
}

int main() {
    int transactions[] = {100, -50, 200, -150, 300, -200, 150, -100, 50, -50};
    int num_transactions = sizeof(transactions) / sizeof(transactions[0]);

    pthread_t threads[num_transactions];

    for (int i = 0; i < num_transactions; i++) {
        pthread_create(&threads[i], NULL, processar_transacao, &transactions[i]); // Cria uma thread para cada transa??o
    }

    for (int i = 0; i < num_transactions; i++) {
        pthread_join(threads[i], NULL); // Aguarda todas as threads terminarem
    }

    printf("Saldo final da conta: %d\n", saldo);
    return 0;
}
當我們選擇具有

多執(zhí)行緒處理的環(huán)境時,我們所說的競爭條件可能會發(fā)生,當兩個執(zhí)行緒存取並修改相同的值時,我們就會出現(xiàn)競爭條件。出現(xiàn)此問題的原因是,由於呼叫之間的競爭,無法保證每個執(zhí)行緒中存取的值的同步。

多次執(zhí)行此程式碼時,最終餘額會有所不同,因為執(zhí)行緒同時存取和更改餘額。

Rust Threads safety: Uma compara??o com C.


3.2.使用互斥體修復

int saldo = 1000; 

void creditar(int valor) {
    int tmp_saldo = saldo;

    sleep(1); // Delay simulado

    saldo += tmp_saldo + valor;
}

void debitar(int valor) {
    int temp = saldo;

    sleep(1); // Delay simulado

    if (temp >= valor) {
        saldo = temp - valor;
    }
}

void* processar_transacao(void* arg) {
    int valor = *(int*)arg;

    if (valor > 0) {
        creditar(valor);
    } else {
        debitar(abs(valor));
    }

    return NULL;
}

int main() {
    int transactions[] = {100, -50, 200, -150, 300, -200, 150, -100, 50, -50};
    int num_transactions = sizeof(transactions) / sizeof(transactions[0]);

    pthread_t threads[num_transactions];

    for (int i = 0; i < num_transactions; i++) {
        pthread_create(&threads[i], NULL, processar_transacao, &transactions[i]); // Cria uma thread para cada transa??o
    }

    for (int i = 0; i < num_transactions; i++) {
        pthread_join(threads[i], NULL); // Aguarda todas as threads terminarem
    }

    printf("Saldo final da conta: %d\n", saldo);
    return 0;
}

互斥體是一種同步原語,可確保一次只有一個執(zhí)行緒可以存取共享資源??s寫互斥體來自英文術語互斥,意思是「互斥」。

當一個執(zhí)行緒取得互斥體時,任何其他嘗試取得相同互斥體的執(zhí)行緒都會被掛起,直到第一個執(zhí)行緒釋放互斥體。這可以防止兩個或多個進程(執(zhí)行緒)同時存取共享資源。

Rust Threads safety: Uma compara??o com C.

4. Rust 中的實現(xiàn)

int saldo = 1000; 
pthread_mutex_t saldo_mutex; // Mutex para proteger o saldo

void creditar(int valor) { 
    pthread_mutex_lock(&saldo_mutex); // Bloqueia o mutex
    int tmp_saldo = saldo;

    sleep(1); // Delay simulado

    saldo = tmp_saldo + valor;

    pthread_mutex_unlock(&saldo_mutex); // Libera o mutex
}

void debitar(int valor) {
    pthread_mutex_lock(&saldo_mutex); // Bloqueia o mutex
    int tmp_saldo = saldo;

    sleep(1); // Delay simulado

    if (tmp_saldo >= valor) {
        saldo = tmp_saldo - valor;
    }

    pthread_mutex_unlock(&saldo_mutex);  // Libera o mutex
}

將Rust 視為一種不存在於資料競賽中的語言並不高效,但我們可以理解結構 及其編譯器如何透過為記憶體和執(zhí)行緒安全帶來出色的功能來做出貢獻。

Rust 使用 所有權、借用 和並發(fā)安全結構等功能,透過編譯時保證來對待競爭條件

  • Arc:安全共享不可變資料。
  • MutexRwLock:可變資料的存取控制。

4.1.競爭條件問題

不使用 Arc 和 Mutex 結構

Rust’s rich type system and ownership model guarantee memory-safety and thread-safety — enabling you to eliminate many classes of bugs at compile-time.

Rust 不允許在沒有保護的情況下從多個線程直接存取可變資料(餘額)。
編譯器將產(chǎn)生錯誤,因為餘額在沒有安全機制的情況下被移動到多個執(zhí)行緒(handle1handle2)。
將顯示的錯誤訊息是:

fn main() {
    let mut saldo = 1000; // saldo mutável, mas sem prote??o

    let handle1 = thread::spawn(move || {
        saldo += 100;  // erro: `saldo` é movido para esta thread sem prote??o
    });

    let handle2 = thread::spawn(move || {
        saldo -= 50;  // erro: `saldo` é movido para esta thread sem prote??o
    });

    handle1.join().unwrap();
    handle2.join().unwrap();
}

4.2.互斥體和弧的解析

使用 Mutex 和 Arc,我們能夠編譯並執(zhí)行我們的程式碼,並解決了競爭條件問題。

error[E0382]: use of moved value: `saldo`

4.3.互斥體對比讀寫鎖

Mutex 和 RwLock 用來處理競爭條件,各自具有特定的優(yōu)點:

互斥體:保證一個執(zhí)行緒對資源的獨佔訪問,阻止對其他執(zhí)行緒的訪問,直到該執(zhí)行緒被釋放。它簡單而有效,但即使是讀取也會阻塞資源,從而在讀取密集的場景中效率較低。

RwLock:使用 .read() 允許多個同時讀取,並使用 .write() 限制獨佔寫入。它非常適合以讀取為主的場景,因為它透過允許讀取操作中的並行性來提高效能。


5. 結論

C 和 Rust 之間的比較突顯了解決競爭條件的不同方法。 C 需要注意避免競爭條件錯誤,而 Rust 除了所有權模型之外還透過 Mutex、RwLock 和 Arc 等工具在編譯時降低了這些風險。這不僅使程式碼更加安全,還透過避免無聲錯誤減少了程式設計師的心理負擔。

總之,Rust 將自己定位為開發(fā)競爭系統(tǒng)的絕佳選擇,提供安全性和可靠性。


6. 參考文獻

  • 附程式碼的倉庫:https://github.com/z4nder/rust-data-races
  • https://en.wikipedia.org/wiki/Race_condition
  • https://blog.bughunt.com.br/o-que-sao-vulnerabilidades-race-condition/
  • https://medium.com/cwi-software/spring-boot-race-condition-e-ambiente-multi-thread-263b21e0042e
  • https://learn.microsoft.com/en-us/troubleshoot/developer/visualstudio/visual-basic/language-compilers/race-conditions-deadlocks
  • https://www.reddit.com/r/rust/comments/18faxjg/understanding_threadsafety_vs_race_conditions/?rdt=52263
  • https://doc.rust-lang.org/nomicon/races.html
  • https://news.ycombinator.com/item?id=23599598

以上是Rust 線路安全性:與 C 的比較。的詳細內容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

本網(wǎng)站聲明
本文內容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
在C中使用std :: Chrono 在C中使用std :: Chrono Jul 15, 2025 am 01:30 AM

std::chrono在C 中用於處理時間,包括獲取當前時間、測量執(zhí)行時間、操作時間點與持續(xù)時間及格式化解析時間。 1.獲取當前時間使用std::chrono::system_clock::now(),可轉換為可讀字符串但係統(tǒng)時鐘可能不單調;2.測量執(zhí)行時間應使用std::chrono::steady_clock以確保單調性,並通過duration_cast轉換為毫秒、秒等單位;3.時間點(time_point)和持續(xù)時間(duration)可相互操作,但需注意單位兼容性和時鐘紀元(epoch)

如何在C中獲得堆棧跟蹤? 如何在C中獲得堆棧跟蹤? Jul 07, 2025 am 01:41 AM

在C 中獲取堆棧跟蹤的方法主要有以下幾種:1.在Linux平臺使用backtrace和backtrace_symbols函數(shù),通過包含獲取調用棧並打印符號信息,需編譯時添加-rdynamic參數(shù);2.在Windows平臺使用CaptureStackBackTrace函數(shù),需鏈接DbgHelp.lib並依賴PDB文件解析函數(shù)名;3.使用第三方庫如GoogleBreakpad或Boost.Stacktrace,可跨平臺並簡化堆棧捕獲操作;4.在異常處理中結合上述方法,在catch塊中自動輸出堆棧信

什麼是C中的POD(普通舊數(shù)據(jù))類型? 什麼是C中的POD(普通舊數(shù)據(jù))類型? Jul 12, 2025 am 02:15 AM

在C 中,POD(PlainOldData)類型是指結構簡單且與C語言數(shù)據(jù)處理兼容的類型。它需滿足兩個條件:具有平凡的拷貝語義,可用memcpy複製;具有標準佈局,內存結構可預測。具體要求包括:所有非靜態(tài)成員為公有、無用戶定義構造函數(shù)或析構函數(shù)、無虛函數(shù)或基類、所有非靜態(tài)成員自身為POD。例如structPoint{intx;inty;}是POD。其用途包括二進制I/O、C互操作性、性能優(yōu)化等??赏ㄟ^std::is_pod檢查類型是否為POD,但C 11後更推薦用std::is_trivia

如何從c打電話給python? 如何從c打電話給python? Jul 08, 2025 am 12:40 AM

要在C 中調用Python代碼,首先要初始化解釋器,然後可通過執(zhí)行字符串、文件或調用具體函數(shù)實現(xiàn)交互。 1.使用Py_Initialize()初始化解釋器並用Py_Finalize()關閉;2.用PyRun_SimpleString執(zhí)行字符串代碼或PyRun_SimpleFile執(zhí)行腳本文件;3.通過PyImport_ImportModule導入模塊,PyObject_GetAttrString獲取函數(shù),Py_BuildValue構造參數(shù),PyObject_CallObject調用函數(shù)並處理返回

C中隱藏了什麼功能? C中隱藏了什麼功能? Jul 05, 2025 am 01:44 AM

functionHidingInc發(fā)生了swhenAderivedClassDefinesAfunctionWithThesamenAmeAsabaseClassFunction,MakeTheBaseVersionInAccessiblethroughthredtheDerivedClass.thishishappenswhishenphenthenthenthebasefunctionisfunctionis notvirtulorsignaturesignaturesignaturesignaturesignaturesignaturesnotmatchforoverRoverriding,and andNousingDeclateClateDeclaratiantiesdeclaratianisingdeclaratrationis

如何將函數(shù)作為C中的參數(shù)傳遞? 如何將函數(shù)作為C中的參數(shù)傳遞? Jul 12, 2025 am 01:34 AM

在C 中,將函數(shù)作為參數(shù)傳遞主要有三種方式:使用函數(shù)指針、std::function和Lambda表達式、以及模板泛型方式。 1.函數(shù)指針是最基礎的方式,適用於簡單場景或與C接口兼容的情況,但可讀性較差;2.std::function結合Lambda表達式是現(xiàn)代C 推薦的方式,支持多種可調用對象且類型安全;3.模板泛型方式最為靈活,適用於庫代碼或通用邏輯,但可能增加編譯時間和代碼體積。捕獲上下文的Lambda必須通過std::function或模板傳遞,不能直接轉換為函數(shù)指針。

C中的無效指針是什麼? C中的無效指針是什麼? Jul 09, 2025 am 02:38 AM

AnullpointerinC isaspecialvalueindicatingthatapointerdoesnotpointtoanyvalidmemorylocation,anditisusedtosafelymanageandcheckpointersbeforedereferencing.1.BeforeC 11,0orNULLwasused,butnownullptrispreferredforclarityandtypesafety.2.Usingnullpointershe

STD ::如何在C中移動工作? STD ::如何在C中移動工作? Jul 07, 2025 am 01:27 AM

std::move並不實際移動任何東西,它只是將對象轉換為右值引用,告知編譯器該對象可被用於移動操作。例如在字符串賦值時,若類支持移動語義,則目標對象可接管源對象資源而無需複制。應使用於需轉移資源且性能敏感的場景,如返回局部對象、插入容器或交換所有權時。但不應濫用,因無移動構造時會退化為拷貝,且移動後原對象狀態(tài)未指定。傳遞或返回對象時適當使用可避免多餘拷貝,但如函數(shù)返回局部變量時可能已有RVO優(yōu)化,加std::move反而可能影響優(yōu)化。易錯點包括誤用在仍需使用的對象、不必要的移動及對不可移動類型

See all articles