博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
IntelliJ IDEA 使用教程十二 - Debug 调试多线程程序
阅读量:6042 次
发布时间:2019-06-20

本文共 1466 字,大约阅读时间需要 4 分钟。

hot3.png

新建 MyRunnable

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();    }    }

打断点

Debug 运行 MyTest.main()

下文默认线程的执行顺序为:线程1->线程2->线程3。(实际情况不一定如此)

你会发现 idea 会停在断点处,上面显示当前线程为“线程1”(注意,这里可能为“线程2”或者“线程3”,因为不确定哪个线程先抢到资源)。

然后继续运行程序 F9,跳到下一个断点

你会发现控制台三个线程的日志都打印出来了

线程1-------------进入线程2-------------进入线程3-------------进入

也就是说,idea 只停留在了“线程1”的断点上,“线程2”和“线程3”的断点直接忽略了。

这不是我们想要的,我们希望每个线程的断点都会停留。可以做如下设置。

设置

断点上直接右键设置

把 All 改为 Thread。如果点了 Make Default ,那么后续加上的断点都是 Thead 设置,之前加上的断点不影响。

把上面的两个断点都改为 Thread 设置,再 Debug 运行 MyTest.main()。

你会发现 idea 首先留在了“线程1”的断点上,F9,继续运行,接着会停留在 “线程2”的断点上,F9,继续运行,又会停留在 “线程3”的断点上。

或者打开断点视图设置

和上面的效果是一样的。

结语

由于本人知识和能力有限,文中如有没说清楚的地方,希望大家能在评论区指出,以帮助我将博文写得更好。

转载于:https://my.oschina.net/u/3523423/blog/1605862

你可能感兴趣的文章
iOS多线程开发系列之(一)NSThread
查看>>
微信小程序初体验(上)- 腾讯ISUX社交用户体验设计成员出品
查看>>
SAP WM Physical Inventory Method ST & PZ
查看>>
一次快速的数据迁移感悟
查看>>
《ELK Stack权威指南(第2版)》一3.6 Java日志
查看>>
C++流的streambuf详解及TCP流的实现
查看>>
《量化金融R语言初级教程》一2.5 协方差矩阵中的噪声
查看>>
beetl 和 shrio 结合
查看>>
相对/绝对路径,cd命令,mkdir/rmdir命令,rm命令
查看>>
tomcat中web.xml各配置项的意义
查看>>
Nodejs学习笔记(二):《node.js开发指南》代码中需要注意的几点
查看>>
Ztree异步加载自动展开节点
查看>>
反射操作公共成员变量
查看>>
Android热修复升级探索——代码修复冷启动方案
查看>>
学校宿舍的深夜之思考
查看>>
VB.NET 生成DBF文件
查看>>
编译安装nginx 1.9.15
查看>>
新的开始~~~
查看>>
字符串的扩展
查看>>
存储过程中调用webservice
查看>>