c++11の死锁

一、死锁的产生

两个mutex的时候,mutex1,mutex2

如果两把锁两个线程的顺序不一致,会造成相互等待释放资源,造成死锁

二、死锁的避免

1、是否需要两把以上的锁,如果不用两把锁,自然不会存在这个问题

2、锁的顺序一致,两个线程中调用的顺序一致

mutex1,mutex2都是

3、std::lock()

 class LogfFile
{
public:
    LogfFile() {
        f.open("log.txt");
    }
    void share_print(std::string msg, int id)
    {
        std::lock(m_mutex1, m_mutex2);
        std::lock_guard<std::mutex> guard(m_mutex1,std::adopt_lock);
        std::lock_guard<std::mutex> guard(m_mutex2, std::adopt_lock);
        cout<< msg << id << endl;

    }
    void share_print2(std::string msg, int id)
    {
        std::lock_guard<std::mutex> guard(m_mutex1, std::adopt_lock);
        std::lock_guard<std::mutex> guard(m_mutex2, std::adopt_lock);
        cout << msg << id << endl;

    }

private:
    std::mutex m_mutex1, m_mutex2;
    std::ofstream f;
};

 

转载于:https://www.cnblogs.com/xietianjiao/p/10450228.html

C++死锁是指在多线程编程中,两个或多个线程互相等待对方释放资源而无法继续执行的情况。这种情况下,程序会陷入无限等待的状态,无法正常运行。 死锁通常发生在多个线程同时访问共享资源时,每个线程都持有一个资源,并且试图获取其他线程持有的资源。当所有线程都无法获取到所需的资源时,就会发生死锁。 为了避免死锁的发生,可以采取以下几种方法: 1. 避免使用多个锁:尽量减少使用多个锁来控制资源的访问,可以使用更细粒度的锁或者使用无锁数据结构来避免死锁的发生。 2. 使用加锁顺序:对于多个资源,确保所有线程以相同的顺序获取锁,这样可以避免死锁的发生。 3. 使用超时机制:在获取锁的过程中设置超时机制,如果超过一定时间还未获取到所需的资源,就主动释放已经获取的资源,避免陷入死锁死锁检测工具是用来检测程序中是否存在潜在的死锁问题的工具。常见的死锁检测工具有: 1. Valgrind:一个开源的内存调试和性能分析工具,其中包含了Helgrind工具,可以检测多线程程序中的死锁问题。 2. ThreadSanitizer:一个用于检测并发错误的工具,可以检测死锁、数据竞争等问题。 3. Visual Studio的并发视图器:在Visual Studio中提供了一个并发视图器,可以帮助开发者分析多线程程序中的死锁问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值