问题描述:事情是这样的,我的程序在运行一个方法,运行到末尾,发现卡住了。
问题排查:我想这代码也没涉及到其他锁的获取啊,怎么会跑不动了呢,通过阅读代码发现,我创建了一个 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(); // 死锁,永远不会返回
欢迎交流~