部分转载来自:https://www.jianshu.com/p/e7565f42f652
总结:
All:
使用all模式对于程序中含有多个线程来说,会将多个线程都阻塞在断点,此时所有的线程都执行到此处,在最后一个线程执行到此处是会发生暂停,在这之前的线程会继续执行到任意位置
Tread:
如果是Thread的模式,那么就会每个线程进行依次进行调试,依次进入各自的断点中。
例如如下程序:
public class Own {
public static void main(String[] args) {
TreadImpl t1 = new TreadImpl("t1");
TreadImpl t2 = new TreadImpl("t2");
Thread t3 = new Thread(()->{
System.out.println(Thread.currentThread().getName()+"start");//断点
System.out.println(Thread.currentThread().getName()+"end");//断点
});
t1.start();
t2.start();
t3.start();
}
}
class TreadImpl extends Thread{
public TreadImpl(String name){
this.setName(name);
}
@Override
public void run(){
System.out.println(this.getName()+"start");//断点
try {
this.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(this.getName()+"end");//断点
}
}
使用All模式输出
t3start
t2start
t3end//由于延时此时t3会在t1线程未到达start的截止点时发生一直向下执行
t1start
t2end
t1end
此时会等待所有线程到达同一断点,再继续往下执行
使用Tread模式输出
t3start
t3end
t2start
t1start
t2end
t1end
此时每到达一个断点的线程就会不截断然后输出,依次遍历输出所有
Condition
对断点的过滤添加自定义条件,我们使用两个线程进行模拟,源代码如下:
public class Own {
public static void main(String[] args) {
TreadImpl t1 = new TreadImpl("t1");
TreadImpl t2 = new TreadImpl("t2");
t1.start();
t2.start();
}
}
class TreadImpl extends Thread{
public TreadImpl(String name){
this.setName(name);
}
@Override
public void run(){
System.out.println(this.getName()+"start");/*添加断点(设置为Tread模式),添加条件:TreadImpl.currentThread().getName().equals("t1")*/
try {
this.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(this.getName()+"end");/*添加断点(设置为Tread模式),不添加条件*/
}
}
对于断点1,我们添加条件:
TreadImpl.currentThread().getName().equals("t1")
断点执行到此处时会进行条件判断,判断条件是否成立,成立则会进行截断,不成立则会忽略
结果:
t2start//并未进行截断
t2end
t1start
t1end