Rust中由于错误使用锁引发的问题,单线程中的死锁现象【已解决】

  问题描述:事情是这样的,我的程序在运行一个方法,运行到末尾,发现卡住了。
  问题排查:我想这代码也没涉及到其他锁的获取啊,怎么会跑不动了呢,通过阅读代码发现,我创建了一个 Arc<Mutexjson::JsonValue>对象,但这个对象并没有涉及到与其他线程的共享,在这段代码中,我在频繁获取这个对象锁进行操作,我就想会不会是该方法中,获取锁的代码冲突了。于是我试着将本来多处获取锁,改为起始位置获取一次,重新运行,OK了。
  总结:问题的根本原因是编码错误,本就不该这么写,给不需要共享的对象上了锁,又在代码中多处获取锁,而Rust 的 std::sync::Mutex 是不支持的重入锁的,最终导致在单线程中出现了死锁现象

let m = Arc::new(Mutex::new(0));

let guard = m.lock().unwrap();
let guard2 = m.lock().unwrap(); // 死锁,永远不会返回

欢迎交流~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值