西安便宜网站建设,c++线上培训机构哪个好,网站移动端怎么做,企业展厅建设重要性c 互斥锁使用详解
std::mutex
用于保护共享资源#xff0c;防止多个线程同时修改共享资源而引发竞争条件。
成员函数
lock#xff1a;锁定互斥#xff0c;若互斥不可用则阻塞。try_lock#xff1a;尝试锁定互斥#xff0c;若互斥不可用则返回。unlock#xff1a;解锁…c 互斥锁使用详解
std::mutex
用于保护共享资源防止多个线程同时修改共享资源而引发竞争条件。
成员函数
lock锁定互斥若互斥不可用则阻塞。try_lock尝试锁定互斥若互斥不可用则返回。unlock解锁互斥。
推荐使用方法
不推荐直接调用 std::mutex 的成员函数若按此处理则在多条代码路径都要调用 unlock包括由于异常导致退出的路径。推荐使用 std::unique_lock 或 std::lock_guard以上两个类模板针对互斥锁实现了 RAII 手法在构造时给互斥加锁在析构时解锁从而保证互斥锁总被正确解锁。
示例代码 以下示例演示了两个线程交替写一个文件 #include stdio.h
#include string.h
#include thread
#include mutexstd::mutex g_mutex;void f1(FILE *fp)
{// 获取互斥锁std::lock_guardstd::mutex lk(g_mutex);// c17 以上可以这样写·// std::lock_guard lk(g_mutex);// 进入临界区访问共享资源const char* s thread1: hello\n;fwrite(s, strlen(s), 1, fp);// RAII自动解锁
}void f2(FILE *fp)
{// 获取互斥锁std::lock_guardstd::mutex lk(g_mutex);// c17 以上可以这样写·// std::lock_guard lk(g_mutex);// 进入临界区访问共享资源const char* s thread2: hello\n;fwrite(s, strlen(s), 1, fp);// RAII自动解锁
}int main()
{// 新建文件FILE* fp fopen(test.txt, wt);// 创建线程std::thread t1(f1, fp);std::thread t2(f2, fp);// 等待线程结束t1.join();t2.join();// 关闭文件fclose(fp);return 0;
}