在Linux中,假设我有100个线程的代码。这些线程中有5个竞争由互斥锁保护的共享资源。我知道当临界区实际运行时,如果5个线程试图获得锁,则只有5个线程会停止执行,而其他95个线程将正常运行。
我的问题是,是否存在其他95个线程的执行将暂停或受影响的时间点,即互斥量/内核/什么决定哪些线程在互斥量上被阻塞,哪个线程应该获得锁,以及哪些线程应该能够运行,因为它们没有请求锁,等等
发布于 2013-03-29 22:03:11
不会,其他线程不受影响。
内核不会询问哪些线程受到锁的影响。每个线程都会在尝试获取锁时通知内核。
当线程这样做时,它们会进入睡眠状态,并进入与锁相关的特殊唤醒队列。
不使用锁的线程不会进入与使用锁的线程相同的队列,因此它们的阻塞行为是无关的。
https://stackoverflow.com/questions/15704777
复制相似问题