C++11 读写锁实现计数器

C++11 读写锁实现计数器

使用函数

rwlock.h

实现 读写锁

#pragma once
#include <mutex> 
#include <shared_mutex>

class ReaderWriterLatch {
private:
	mutable std::shared_mutex mutex_;
public:
	void WLock() { mutex_.lock(); } // 获取写锁

	void WUnlock() { mutex_.unlock(); } // 释放写锁

	void RLock() { mutex_.lock_shared(); } // 获得读锁
	
	void RUnlock() { mutex_.unlock_shared(); }// 释放读锁
};

main.cpp

主函数,实现多线程

#include <iostream>
#include "rwlock.h"
#include <thread>
#include <vector>
using namespace std;

ReaderWriterLatch latch;
int cnt = 0;

void read() {
    while (1) {
        latch.RLock();
        cout << "read count, count: " << cnt << "\tpid: " << std::this_thread::get_id() << endl;
        latch.RUnlock();
        this_thread::sleep_for(std::chrono::milliseconds(200));
    }
}

void write() {
    while (1) {
        latch.WLock();
        cnt++;
        cout << "write count, count: " << cnt << "\tpid: " << std::this_thread::get_id() << endl;
        latch.WUnlock();
        this_thread::sleep_for(std::chrono::milliseconds(200));
    }
}

int main() {
    // 创建多个读线程和多个写线程
    int num = 5;
    vector<thread> readThreads;
    vector<thread> writeThreads;

    for (int i = 0; i < num; i++) {
        readThreads.emplace_back(read);   //五个线程去执行 read()
        writeThreads.emplace_back(write); // 五个线程去执行 write()
    }

    // 主线程阻塞 等待子线程完成任务后回收资源
    for (auto& thread : readThreads) thread.join();
    for (auto& thread : writeThreads) thread.join();

    system("pause");
    return 0;
}

结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值