面试二十六、c++语言级别的多线程编程

一、 多线程编程

​​​​​

这里的c++语言级别的多线程和linux的有一定的区别,c++语言级别提供的多线程比较严格,如果主线程结束了,但是子线程没有结束,进程就会异常终止,而linux不会,会继续执行。

二、模拟卖票

2.1 使用mutex互斥量
2.2 使用lock_guard(栈上对象出作用域析构),但是不支持拷贝构造和赋值重载,在函数调用和参数传递过程中就不能使用。和智能指针的socped_ptr类似
3.unique_lock 和 unique_ptr相似

unique_lock允许右值引用的拷贝构造和赋值,

三、线程间同步通信机制

cpp 复制代码
#include <iostream>
#include <thread>
#include <shared_mutex>
#include <vector>
#include <chrono>

class ReadWriteLock {
public:
    void read() {
        std::shared_lock<std::shared_mutex> lock(mutex_);
        std::cout << "Thread " << std::this_thread::get_id() << " is reading." << std::endl;
        std::this_thread::sleep_for(std::chrono::milliseconds(100)); // 模拟读取操作
        std::cout << "Thread " << std::this_thread::get_id() << " has finished reading." << std::endl;
    }

    void write() {
        std::unique_lock<std::shared_mutex> lock(mutex_);
        std::cout << "Thread " << std::this_thread::get_id() << " is writing." << std::endl;
        std::this_thread::sleep_for(std::chrono::milliseconds(100)); // 模拟写入操作
        std::cout << "Thread " << std::this_thread::get_id() << " has finished writing." << std::endl;
    }

private:
    std::shared_mutex mutex_;
};

void reader(ReadWriteLock& rw_lock) {
    for (int i = 0; i < 5; ++i) {
        rw_lock.read();
    }
}

void writer(ReadWriteLock& rw_lock) {
    for (int i = 0; i < 5; ++i) {
        rw_lock.write();
    }
}

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

    // 启动多个读线程
    for (int i = 0; i < 3; ++i) {
        threads.emplace_back(reader, std::ref(rw_lock));
    }

    // 启动多个写线程
    for (int i = 0; i < 2; ++i) {
        threads.emplace_back(writer, std::ref(rw_lock));
    }

    // 等待所有线程完成
    for (auto& t : threads) {
        t.join();
    }

    return 0;
}

自旋锁(spinlock)是一种用于多线程同步的锁机制,通过忙等待(不断地检查锁的状态)来实现,而不是将线程挂起或阻塞。自旋锁的主要特点是,当一个线程试图获取锁但锁已经被其他线程持有时,它会在一个循环中反复检查锁的状态,直到锁被释放。由于自旋锁在等待时不进行上下文切换,因此它适用于锁定时间很短的场景。

四、lock_guard 和 unique_lock

五、CAS

相关推荐
java1234_小锋1 小时前
Java高频面试题:Redis到底支不支持事务啊?
java·redis·面试
big_rabbit05022 小时前
[算法][力扣167]Two Sum II
算法·leetcode·职场和发展
我叫黑大帅2 小时前
Golang中实时推送的功臣 - WebSocket
后端·面试·go
Eward-an3 小时前
LeetCode 76. 最小覆盖子串(详细技术解析)
python·算法·leetcode·职场和发展
QD_ANJING3 小时前
3月面大厂前端岗总结笔记(含答案)
前端·javascript·笔记·面试·职场和发展·前端框架·pdf
逆境不可逃4 小时前
LeetCode 热题 100 之 394. 字符串解码 739. 每日温度 84. 柱状图中的最大矩形
算法·leetcode·职场和发展
重生之后端学习4 小时前
62. 不同路径
开发语言·数据结构·算法·leetcode·职场和发展·深度优先
y芋泥啵啵gfe4 小时前
AI考研深造VS直接工作:选对赛道,认证为竞争力加码
人工智能·职场和发展
big_rabbit05024 小时前
[算法][力扣283]Move Zeros
算法·leetcode·职场和发展
默默学前端5 小时前
HTML 高频面试题 5 道|吃透基础,面试不慌(附详细解析)
前端·面试·职场和发展·html5