idea以任意顺序debug多线程程序的具体用法


Posted in Java/Android onAugust 30, 2021

在idea中使用debug可以让多个线程以任意顺序执行,先介绍一下基础知识,然后介绍具体做法。

1 debug 两类 Supspend

在断点处右键,可以看到Suspend分两类,一类是All,一类是Thread。当某个线程到达断点处会触发Suspend,All会使得所有线程都暂停,Thread只会使当前触发的线程暂停,其他线程不受影响。

在idea中使用debug可以让多个线程以任意顺序执行,先介绍一下基础知识,然后介绍具体做法。

idea以任意顺序debug多线程程序的具体用法

以下面的代码为例,有3个MyThread线程以及一个主线程main。3个线程分别睡眠 1/2/3 秒,主线程睡眠 5 秒。下面分三种情况查看结果:

  1. 正常执行,执行完的顺序为 1, 2, 3, main
  2. 在断点1处打断点,设置为 All,在线程1触发后所有线程均暂停,可以通过Resume继续执行下一个断点,正常情况应该是3次Resume才能结束,但在有些时候idea会提示 skipped breakpoint at because it happened inside debugger evaluation,会跳过一些断点,这可能是ide本身的问题,可以在Settings->Build … ->Debugger->Data Views->Java中 取消 Enable ‘toString()' object view。
  3. 在断点1处打断点,设置为 Thread,3个子线程都会在断点处暂停,main线程没有暂停,会先执行完。
package org.example;

public class Test{
    public static void main(String arg[]){
        MyThread thread1 = new MyThread(1);
        MyThread thread2 = new MyThread(2);
        MyThread thread3 = new MyThread(3);

        thread1.setName("Thread 1");
        thread2.setName("Thread 2");
        thread3.setName("Thread 3");

        thread1.start();
        thread2.start();
        thread3.start();

        try {
            Thread.sleep(1000*5);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("主线程完成");
    }

    private static class MyThread extends Thread {
        private int num;
        public MyThread(int num) {
            this.num = num;
        }
        @Override
        public void run() {
            String name = Thread.currentThread().getName();
            try {
                Thread.sleep(1000*num);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"断点1"); //断点1
            System.out.println(Thread.currentThread().getName()+"断点之间执行");
            System.out.println(Thread.currentThread().getName()+"断点2"); //断点2       
        }
    }

2 按照顺序执行线程

在子线程打两个Thread断点,通过Frames控制子线程的执行顺序,假设断点之间的执行顺序为3, 2, 1, 2, 1, 3。其中第一次执行从断点1开始,执行到断点2之前,第二次执行会执行断点2并结束。

如果感觉不好理解,可以将MyThread换成三个不同的类分别对应三个线程,在三个类中分别打断点。这里我不再替换。

debug运行,稍等一会,三个线程都会到第一个断点停下,此时未有任何输出,注意在左下角Frames的菜单,点开,会发现三个线程都在Frames内,这说明三个线程都已经暂停,有时候下拉框会有main,但其实main不会暂停。

idea以任意顺序debug多线程程序的具体用法

想先执行Thread 3,则在下拉框选择Thread 3,点一下Resume,此时Thread 3的第一个断点和断点之间的代码执行,Thread 3暂停在第二个断点上,其他暂停的线程不受影响。

idea以任意顺序debug多线程程序的具体用法

对应的后续执行顺序是,切换到Thread 2/1/2/1/3,每次切换都Resume一次。

总结:想让哪个线程先执行就在下拉框切换到相应的线程,并Resume,则该线程执行到下一个断点,如果没有下一个断点则会一直执行直到结束。此时,其他暂停的线程会一直暂停等待。

这样的做法可以推广到多个线程,对于需要暂停的线程都打上断点即可,每个线程可以打多个,方便控制执行顺序。对于不需要暂停的线程可以不打断点,就像这里的main线程一样。

3 Condition的使用

另外如果只想让某个线程在断点处停止,可以使用断点的Condition,如上面的代码中只想让第一个线程暂停,则可以在断点处右键,在Condition中填入Thread.currentThread().getName().equals(“Thread 1”);

idea以任意顺序debug多线程程序的具体用法

到此这篇关于idea以任意顺序debug多线程程序的文章就介绍到这了,更多相关idea多线程debug内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Java/Android 相关文章推荐
jackson json序列化实现首字母大写,第二个字母需小写
Jun 29 Java/Android
一篇文章带你学习Mybatis-Plus(新手入门)
Aug 02 Java/Android
springboot如何接收application/x-www-form-urlencoded类型的请求
Nov 02 Java/Android
Spring事务管理下synchronized锁失效问题的解决方法
Mar 31 Java/Android
Java中的继承、多态以及封装
Apr 11 Java/Android
java中为什么说子类的构造方法默认访问的是父类的无参构造方法
Apr 13 Java/Android
Spring Boot接口定义和全局异常统一处理
Apr 20 Java/Android
Java服务调用RestTemplate与HttpClient的使用详解
Jun 21 Java/Android
Android RecyclerView实现九宫格效果
Jun 28 Java/Android
springboot+rabbitmq实现智能家居实例详解
Jul 23 Java/Android
Spring Boot实现文件上传下载
Aug 14 Java/Android
Java获取字符串编码格式实现思路
Sep 23 Java/Android
Logback 使用TurboFilter实现日志级别等内容的动态修改操作
Aug 30 #Java/Android
Java SSM配置文件案例详解
Aug 30 #Java/Android
java调用Restful接口的三种方法
Aug 23 #Java/Android
JVM钩子函数的使用场景详解
Java中CyclicBarrier和CountDownLatch的用法与区别
Aug 23 #Java/Android
SpringBoot整合Mybatis Generator自动生成代码
Aug 23 #Java/Android
Java面试题冲刺第十九天--数据库(4)
You might like
Yii2.0表关联查询实例分析
2016/07/18 PHP
php+ajax登录跳转登录实现思路
2016/07/31 PHP
入门基础学习 ExtJS笔记(一)
2010/11/11 Javascript
实用的Jquery选项卡TAB示例代码
2013/08/28 Javascript
jquery 提示信息显示后自动消失的具体实现
2013/12/18 Javascript
jQuery性能优化的38个建议
2014/03/04 Javascript
详细解读AngularJS中的表单验证编程
2015/06/19 Javascript
javascript生成不重复的随机数
2015/07/17 Javascript
Nodejs express框架一个工程中同时使用ejs模版和jade模版
2015/12/28 NodeJs
基于jQuery实现带动画效果超炫酷的弹出对话框(附源码下载)
2016/02/22 Javascript
JS 动态判断PC和手机浏览器实现代码
2016/09/21 Javascript
JS实现禁止鼠标右键的功能
2016/10/15 Javascript
原生Javascript插件开发实践
2017/01/09 Javascript
jQuery实现广告条滚动效果
2017/08/22 jQuery
node跨域请求方法小结
2017/08/25 Javascript
JavaScript中this用法学习笔记
2019/03/17 Javascript
微信小程序判断用户是否需要再次授权获取个人信息
2019/07/18 Javascript
在vue中使用防抖和节流,防止重复点击或重复上拉加载实例
2019/11/13 Javascript
微信小程序自定义纯净模态框(弹出框)的实例代码
2020/03/09 Javascript
浅谈vue中get请求解决传输数据是数组格式的问题
2020/08/03 Javascript
vue-quill-editor插入图片路径太长问题解决方法
2021/01/08 Vue.js
[01:14]英雄,所敬略同——2018完美盛典宣传视频
2018/12/05 DOTA
python实现支持目录FTP上传下载文件的方法
2015/06/03 Python
python实现判断数组是否包含指定元素的方法
2015/07/15 Python
python魔法方法-属性访问控制详解
2016/07/25 Python
Django文件上传与下载(FileFlid)
2019/10/06 Python
python实现按关键字筛选日志文件
2019/12/24 Python
Python使用20行代码实现微信聊天机器人
2020/06/05 Python
python virtualenv虚拟环境配置与使用教程详解
2020/07/13 Python
党的群众路线教育实践活动宣传标语口号
2014/06/06 职场文书
创建文明城市标语
2014/06/16 职场文书
城管执法人员个人对照检查材料思想汇报
2014/09/29 职场文书
个人贷款收入证明
2014/10/26 职场文书
2015年初中教务处工作总结
2015/07/21 职场文书
探讨Java中的深浅拷贝问题
2021/06/26 Java/Android
mysql 体系结构和存储引擎介绍
2022/05/06 MySQL