public class MyRunnable implements Runnable { @Override public void run() { Thread currentThread = Thread.currentThread(); System.out.println(currentThread.getName() + "-------------进入"); try { TimeUnit.SECONDS.sleep(5); } catch (InterruptedException e) { e.printStackTrace(); } finally { System.out.println(currentThread.getName() + "-------------离开"); } } }
public class MyTest { public static void main(String[] args) { MyRunnable myRunnable = new MyRunnable(); Thread thread1 = new Thread(myRunnable, "线程1"); Thread thread2 = new Thread(myRunnable, "线程2"); Thread thread3 = new Thread(myRunnable, "线程3"); thread1.start(); thread2.start(); thread3.start(); } }
下文默认线程的执行顺序为:线程1->线程2->线程3。(实际状况不必定如此)ide
你会发现 idea 会停在断点处,上面显示当前线程为“线程1”(注意,这里可能为“线程2”或者“线程3”,由于不肯定哪一个线程先抢到资源)。idea
而后继续运行程序 F9,跳到下一个断点线程
你会发现控制台三个线程的日志都打印出来了日志
线程1-------------进入 线程2-------------进入 线程3-------------进入
也就是说,idea 只停留在了“线程1”的断点上,“线程2”和“线程3”的断点直接忽略了。code
这不是咱们想要的,咱们但愿每一个线程的断点都会停留。能够作以下设置。blog
把 All 改成 Thread。若是点了 Make Default ,那么后续加上的断点都是 Thead 设置,以前加上的断点不影响。资源
把上面的两个断点都改成 Thread 设置,再 Debug 运行 MyTest.main()。get
你会发现 idea 首先留在了“线程1”的断点上,F9,继续运行,接着会停留在 “线程2”的断点上,F9,继续运行,又会停留在 “线程3”的断点上。it
和上面的效果是同样的。io
因为本人知识和能力有限,文中若有没说清楚的地方,但愿你们能在评论区指出,以帮助我将博文写得更好。