>  기사  >  백엔드 개발  >  C++의 멀티스레딩에서 공유 리소스를 처리하는 방법은 무엇입니까?

C++의 멀티스레딩에서 공유 리소스를 처리하는 방법은 무엇입니까?

WBOY
WBOY원래의
2024-06-03 10:28:57999검색

C++에서 뮤텍스(뮤텍스)를 사용하여 다중 스레드 공유 리소스를 처리합니다. std::mutex를 통해 뮤텍스를 만듭니다. 공유 리소스에 대한 독점 액세스를 위한 뮤텍스를 얻으려면 mtx.lock()을 사용하십시오. 뮤텍스를 해제하려면 mtx.unlock()을 사용하세요.

C++의 멀티스레딩에서 공유 리소스를 처리하는 방법은 무엇입니까?

C++의 멀티스레딩에서 공유 리소스 처리

소개

멀티 스레드 프로그래밍에서 여러 스레드가 동시에 공유 리소스에 액세스하면 스레드 안전 문제가 발생합니다. Mutex(뮤텍스)는 하나의 스레드만 동시에 공유 리소스에 액세스할 수 있도록 하여 데이터 경쟁과 손상을 방지하는 동기화 메커니즘입니다.

뮤텍스의 구문 및 사용법

C++에서는 std::mutex를 사용하여 뮤텍스를 만들 수 있습니다. std::mutex 来创建互斥量:

std::mutex mtx;

要对共享资源进行排他访问,需要使用 lock()unlock()

mtx.lock(); // 获取互斥量
// 对共享资源进行操作
mtx.unlock(); // 释放互斥量

공유 리소스에 단독으로 액세스하려면 lock() 및 unlock() 메서드:

#include <iostream>
#include <thread>
#include <mutex>

std::mutex mtx;
int shared_resource = 0;

void increment_resource() {
    mtx.lock();
    shared_resource++;
    mtx.unlock();
}

int main() {
    std::vector<std::thread> threads;

    // 创建多个线程并行执行 increment_resource() 函数
    for (int i = 0; i < 1000; i++) {
        threads.push_back(std::thread(increment_resource));
    }

    // 等待所有线程执行完毕
    for (auto& thread : threads) {
        thread.join();
    }

    // 打印共享资源的最终值,此时的值应该是 1000
    std::cout << shared_resource << std::endl;

    return 0;
}
실용 사례

다음은 공유 리소스를 보호하기 위해 뮤텍스를 사용하는 실제 사례입니다.🎜rrreee

위 내용은 C++의 멀티스레딩에서 공유 리소스를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.