设为首页 收藏本站
查看: 218|回复: 1

[经验分享] C++面试八股文:如何避免死锁?

[复制链接]
累计签到:53 天
连续签到:2 天
发表于 2025-2-12 14:34:24 | 显示全部楼层 |阅读模式
某日二师兄参加XXX科技公司的C++工程师开发岗位第31面:
面试官:什么是锁?有什么作用?
二师兄:在C++中,锁(Lock)是一种同步工具,用于保护共享资源,防止多个线程同时访问,从而避免数据竞争和不一致。
面试官:有哪些锁?
二师兄:从种类上分,可以分为普通锁、读写锁、递归锁等种类。
二师兄:从实现上分,可以分为互斥锁、自旋锁、信号量、条件变量等。
面试官:互斥锁如何使用?
二师兄:在C++11之前,C++便准层面并没有定义锁,锁的应用要依赖于平台。Linux下使用pthread库中的mutex;

[C++] 纯文本查看 复制代码
#include <pthread.h>
pthread_mutex_t mutex_ = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_lock(&mutex_);
//被保护的区域
pthread_mutex_unlock(&mutex_);
[quote]二师兄:C++11引入了std::mutex,统一了各个平台上互斥锁的使用:[/quote]
[mw_shl_code=cpp,true]#include <mutex>
std::mutex mutex_;
mutex_.lock();
//被保护的区域
mutex_.unlock();
[/mw_shl_code]
面试官:pthread_mutex和std::mutex有没有非阻塞的api?
二师兄:有的,分别是pthread_mutex_trylock()和try_lock(),当获取不到锁时这两者并不阻塞当前线程,而是立即返回。需要注意的是,当pthread_mutex_trylock()获取到锁时返回0,而std::mutex::try_lock()方法获取不到锁时返回false。
面试官:std::lock_guard和std::unique_lock用过吗?
二师兄:用过。
面试官:两者有什么相同点和不同点?
二师兄:相同点是两者都使用RAII(资源获取即初始化)技术实现的锁,支持自动上锁,自动解锁。二师兄:不同点主要包括三个方面:1.灵活性:std::unqiue_lock的灵活性要高于std::lock_gurad,std::unique_lock可以在任何时间解锁和锁定,而std::lock_guard在构造时锁定,在析构时解锁,不能手动控制。2.所有权:std::unique_lock支持所有权转移,而std::lock_gurad不支持。3.性能:由于std::unique_lock的灵活性更高,它的性能可能会稍微低一些。
面试官:能实现一个lock_gurad吗?
二师兄:我尝试一下:
class lock_guard

[C++] 纯文本查看 复制代码
{
    explicit lock_guard(std::mutex& m):mutex_(m)
    {
        mutex_.lock();
    }
    ~lock_guard()
    {
        mutex_unlock();
    }
private:
    std::mutex& mutex_;
};
面试官:为什么会发生死锁?
二师兄:当进程A持有锁1请求锁2,进程B持有锁2请求锁1时,两者都不会释放自己的锁,两者都需要对方的锁,就会造成死锁。当然现实中可能比这要复杂,但原理是相同的。
面试官:如何避免死锁?
二师兄:主要从以下几个方面入手:1.避免循环等待,如果需要在业务中获取不同的锁,保证所有业务按照相同的顺序获取锁。2.使用超时锁,当锁超时时,自动释放锁。3.使用try_lock,当锁被占用时,返回false并继续执行。4.锁的粒度尽量要小,只保护竟态数据而不是整个流程。
面试官:知道adopt_lock_t/defer_lock_t/try_to_lock_t这三种类型的用法吗?
二师兄:额。。不知道。。
面试官:好的,回去等通知吧。

让我们来看看最后一个问题:
知道adopt_lock_t/defer_lock_t/try_to_lock_t这三种类型的用法吗?
adopt_lock_t/defer_lock_t/try_to_lock_t都是空类,主要表示std::lock_gurad和std::unqiue_lock的默认构造中的操作:
adopt_lock_t:默认互斥量已被当前线程锁定,不使用lock()方法对互斥量加锁:
std::mutex mtx_;mtx_.lock();        //lock{    std::lock_guard<std::mutex> lock_(mtx_,std::adopt_lock);        //这里默认当前线程已经对mtx_加过锁    ...}//unlockdefer_lock_t:虽然我拥有了std::mutex的引用,但是在构造函数中并不调用lock()方法对互斥量加锁:
std::mutex mtx_;{    std::unique_lock<std::mutex> ulock_(mtx_,std::defer_lock);        //这里并没有加锁    ulock_.lock();    if(ulock_.owns_lock())    {                //locked    }else    {                //unlocked    }}//if locked,unlocktry_to_lock_t:在构造函数执行是并不是使用lock()方法加锁,而是使用try_lock()方法加锁:
std::mutex mtx_;{    std::unique_lock<std::mutex> ulock_(mtx_,std::try_to_lock);        //这里mtx_如果没有被锁定,则加锁成功,否则加锁失败    if(ulock_.owns_lock())    {                //locked    }else    {                //unlocked    }}//if locked,unlockadopt_lock_t可以用于std::lock_gurad和std::unique_lock,而defer_lock_t/try_to_lock_t只能用于std::unique_lock。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-1005680-1-1.html 上篇帖子: C++面试八股文:如何实现一个strncpy函数? 下篇帖子: 谁还不知道这个嘎嘎厉害的C++构建工具!
累计签到:53 天
连续签到:2 天
 楼主| 发表于 2025-2-12 14:36:00 | 显示全部楼层
<顺便吆喝一句,民族企业大厂,前后端测试捞人,感兴趣的来!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表