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

 更新时间:2021年08月30日 10:41:44   作者:Java与大数据进阶  
在idea中使用debug可以让多个线程以任意顺序执行,接下来通过本文给大家介绍idea以任意顺序debug多线程程序的具体用法,需要的朋友参考下吧

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

1 debug 两类 Supspend

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

在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不会暂停。

在这里插入图片描述

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

在这里插入图片描述

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

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

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

3 Condition的使用

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

在这里插入图片描述

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

相关文章

  • Java中死锁的原理实战分析

    Java中死锁的原理实战分析

    这篇文章主要介绍了Java中死锁的原理,结合具体案例形式分析了java死锁形成的相关原理,需要的朋友可以参考下
    2019-08-08
  • java中优化大量if...else...方法总结

    java中优化大量if...else...方法总结

    在我们平时的开发过程中,经常可能会出现大量If else的场景,代码显的很臃肿,非常不优雅,下面这篇文章主要给大家介绍了关于java中优化大量if...else...方法的相关资料,需要的朋友可以参考下
    2023-03-03
  • java安全fastjson1.2.24反序列化TemplatesImpl分析

    java安全fastjson1.2.24反序列化TemplatesImpl分析

    这篇文章主要介绍了java安全fastjson1.2.24反序列化TemplatesImpl分析,fastjson是alibaba开源的一个用于处理json数据格式的解析库,它支持将java对象解析成json字符串格式的数据,也可以将json字符串还原成java对象
    2022-07-07
  • 图文示例详解Lucene数据模型查询原理

    图文示例详解Lucene数据模型查询原理

    这篇文章主要为大家通过图文示例详解Lucene数据模型查询原理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • Mybatis如何实现@Select等注解动态组合SQL语句

    Mybatis如何实现@Select等注解动态组合SQL语句

    这篇文章主要介绍了Mybatis如何实现@Select等注解动态组合SQL语句,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Spring @Component自定义注解实现详解

    Spring @Component自定义注解实现详解

    @Component是一个元注解,意思是可以注解其他类注解,如@Controller @Service @Repository @Aspect。官方的原话是:带此注解的类看为组件,当使用基于注解的配置和类路径扫描的时候,这些类就会被实例化
    2022-09-09
  • Java 添加、替换、删除PDF中的图片的示例代码

    Java 添加、替换、删除PDF中的图片的示例代码

    这篇文章主要介绍了Java 添加、替换、删除PDF中的图片,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • Quartz高可用定时任务的快速上手指南

    Quartz高可用定时任务的快速上手指南

    Quartz的分布式策略就是一种以数据库作为边界资源的并发策略,每个节点都遵守相同的操作规范,使得对数据库的操作可以串行执行,而不同名称的调度器又可以互不影响的并行运行,下面这篇文章主要介绍了Quartz高可用定时任务快速上手的相关资料,需要的朋友可以参考下
    2022-04-04
  • Maven的生命周期与自定义插件实现方法

    Maven的生命周期与自定义插件实现方法

    Maven的生命周期就是对所有的构建过程进行抽象和统一。包含了项目的清理、初始化、编译、测试、打包、集成测试、验证、部署和站点生成等几乎所有的构建步骤
    2022-12-12
  • 23种设计模式(3) java原型模式

    23种设计模式(3) java原型模式

    这篇文章主要为大家详细介绍了23种设计模式之java原型模式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11

最新评论