多线程断点调试,在观察多线程执行过程的时候非常有用。下面是一段多线程代码:
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class AQSDebug {
private Lock lock = new ReentrantLock();
private void sayHello(){
lock.lock();
System.out.println("hello");
lock.unlock();
}
public static void main(String[] args) {
AQSDebug aqsDebug = new AQSDebug();
new Thread(aqsDebug::sayHello,"first").start();
new Thread(aqsDebug::sayHello,"second").start();
new Thread(aqsDebug::sayHello,"third").start();
}
}
这段代码是为了观察AQS加锁,排队等待、唤醒的过程而写的,为了让观察第一个线程获取锁之后,后面两个线程排队后等待,以及唤醒重新获取锁的过程。我们需要进行多线程调试。首先,在第8行加上断点,设置如下:
suspend选项如果设置为all,就会出现第一个线程启动后直接阻塞。而如果suspend选项设置为Thread,那么不同的线程可以并发到这个断点。
运行debug后,三个线程都被拦在了断点处,我们单步调试线程first,让他获取到锁。然后切换到线程second或者third进行单步调试,会看到因获取不到锁而被加入同步队列之后阻塞的过程。
其中切换线程进行调试,是点击这里进行选择切换。