在C++中,库函数的并发控制通常是通过互斥锁(mutex)来实现的。互斥锁是一种同步原语,用于保护共享资源免受多个线程的并发访问。当一个线程获得互斥锁时,其他线程必须等待该线程释放锁后才能继续访问共享资源。
C++标准库提供了std::mutex
类来实现互斥锁。以下是一个使用std::mutex
的示例:
#include<iostream>
#include<thread>
#include <mutex>
std::mutex mtx; // 全局互斥锁
int shared_data = 0; // 共享数据
void thread_function() {
std::unique_lock<std::mutex> lock(mtx); // 获取互斥锁
++shared_data; // 修改共享数据
lock.unlock(); // 释放互斥锁
}
int main() {
std::thread t1(thread_function);
std::thread t2(thread_function);
t1.join();
t2.join();
std::cout << "Shared data: "<< shared_data<< std::endl;
return 0;
}
在这个示例中,我们创建了两个线程,它们都会调用thread_function
。thread_function
首先获取互斥锁,然后修改共享数据shared_data
,最后释放互斥锁。这样可以确保在任何时候只有一个线程能够访问和修改shared_data
,从而避免数据竞争和不一致的问题。
除了std::mutex
之外,C++标准库还提供了其他同步原语,如std::condition_variable
、std::atomic
等,可以根据具体需求选择合适的同步机制。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。