欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

idea以任意順序debug多線程程序的具體用法

 更新時(shí)間:2021年08月30日 10:41:44   作者:Java與大數(shù)據(jù)進(jìn)階  
在idea中使用debug可以讓多個(gè)線程以任意順序執(zhí)行,接下來通過本文給大家介紹idea以任意順序debug多線程程序的具體用法,需要的朋友參考下吧

在idea中使用debug可以讓多個(gè)線程以任意順序執(zhí)行,先介紹一下基礎(chǔ)知識(shí),然后介紹具體做法。

1 debug 兩類 Supspend

在斷點(diǎn)處右鍵,可以看到Suspend分兩類,一類是All,一類是Thread。當(dāng)某個(gè)線程到達(dá)斷點(diǎn)處會(huì)觸發(fā)Suspend,All會(huì)使得所有線程都暫停,Thread只會(huì)使當(dāng)前觸發(fā)的線程暫停,其他線程不受影響。

在idea中使用debug可以讓多個(gè)線程以任意順序執(zhí)行,先介紹一下基礎(chǔ)知識(shí),然后介紹具體做法。

在這里插入圖片描述

以下面的代碼為例,有3個(gè)MyThread線程以及一個(gè)主線程main。3個(gè)線程分別睡眠 1/2/3 秒,主線程睡眠 5 秒。下面分三種情況查看結(jié)果:

  1. 正常執(zhí)行,執(zhí)行完的順序?yàn)?1, 2, 3, main
  2. 在斷點(diǎn)1處打斷點(diǎn),設(shè)置為 All,在線程1觸發(fā)后所有線程均暫停,可以通過Resume繼續(xù)執(zhí)行下一個(gè)斷點(diǎn),正常情況應(yīng)該是3次Resume才能結(jié)束,但在有些時(shí)候idea會(huì)提示 skipped breakpoint at because it happened inside debugger evaluation,會(huì)跳過一些斷點(diǎn),這可能是ide本身的問題,可以在Settings->Build … ->Debugger->Data Views->Java中 取消 Enable ‘toString()' object view。
  3. 在斷點(diǎn)1處打斷點(diǎn),設(shè)置為 Thread,3個(gè)子線程都會(huì)在斷點(diǎn)處暫停,main線程沒有暫停,會(huì)先執(zhí)行完。
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()+"斷點(diǎn)1"); //斷點(diǎn)1
            System.out.println(Thread.currentThread().getName()+"斷點(diǎn)之間執(zhí)行");
            System.out.println(Thread.currentThread().getName()+"斷點(diǎn)2"); //斷點(diǎn)2       
        }
    }

2 按照順序執(zhí)行線程

在子線程打兩個(gè)Thread斷點(diǎn),通過Frames控制子線程的執(zhí)行順序,假設(shè)斷點(diǎn)之間的執(zhí)行順序?yàn)?, 2, 1, 2, 1, 3。其中第一次執(zhí)行從斷點(diǎn)1開始,執(zhí)行到斷點(diǎn)2之前,第二次執(zhí)行會(huì)執(zhí)行斷點(diǎn)2并結(jié)束。

如果感覺不好理解,可以將MyThread換成三個(gè)不同的類分別對(duì)應(yīng)三個(gè)線程,在三個(gè)類中分別打斷點(diǎn)。這里我不再替換。

debug運(yùn)行,稍等一會(huì),三個(gè)線程都會(huì)到第一個(gè)斷點(diǎn)停下,此時(shí)未有任何輸出,注意在左下角Frames的菜單,點(diǎn)開,會(huì)發(fā)現(xiàn)三個(gè)線程都在Frames內(nèi),這說明三個(gè)線程都已經(jīng)暫停,有時(shí)候下拉框會(huì)有main,但其實(shí)main不會(huì)暫停。

在這里插入圖片描述

想先執(zhí)行Thread 3,則在下拉框選擇Thread 3,點(diǎn)一下Resume,此時(shí)Thread 3的第一個(gè)斷點(diǎn)和斷點(diǎn)之間的代碼執(zhí)行,Thread 3暫停在第二個(gè)斷點(diǎn)上,其他暫停的線程不受影響。

在這里插入圖片描述

對(duì)應(yīng)的后續(xù)執(zhí)行順序是,切換到Thread 2/1/2/1/3,每次切換都Resume一次。

總結(jié):想讓哪個(gè)線程先執(zhí)行就在下拉框切換到相應(yīng)的線程,并Resume,則該線程執(zhí)行到下一個(gè)斷點(diǎn),如果沒有下一個(gè)斷點(diǎn)則會(huì)一直執(zhí)行直到結(jié)束。此時(shí),其他暫停的線程會(huì)一直暫停等待。

這樣的做法可以推廣到多個(gè)線程,對(duì)于需要暫停的線程都打上斷點(diǎn)即可,每個(gè)線程可以打多個(gè),方便控制執(zhí)行順序。對(duì)于不需要暫停的線程可以不打斷點(diǎn),就像這里的main線程一樣。

3 Condition的使用

另外如果只想讓某個(gè)線程在斷點(diǎn)處停止,可以使用斷點(diǎn)的Condition,如上面的代碼中只想讓第一個(gè)線程暫停,則可以在斷點(diǎn)處右鍵,在Condition中填入Thread.currentThread().getName().equals(“Thread 1”);

在這里插入圖片描述

到此這篇關(guān)于idea以任意順序debug多線程程序的文章就介紹到這了,更多相關(guān)idea多線程debug內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mybatis如何實(shí)現(xiàn)@Select等注解動(dòng)態(tài)組合SQL語句

    Mybatis如何實(shí)現(xiàn)@Select等注解動(dòng)態(tài)組合SQL語句

    這篇文章主要介紹了Mybatis如何實(shí)現(xiàn)@Select等注解動(dòng)態(tài)組合SQL語句,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Spring @Component自定義注解實(shí)現(xiàn)詳解

    Spring @Component自定義注解實(shí)現(xiàn)詳解

    @Component是一個(gè)元注解,意思是可以注解其他類注解,如@Controller @Service @Repository @Aspect。官方的原話是:帶此注解的類看為組件,當(dāng)使用基于注解的配置和類路徑掃描的時(shí)候,這些類就會(huì)被實(shí)例化
    2022-09-09
  • Java 添加、替換、刪除PDF中的圖片的示例代碼

    Java 添加、替換、刪除PDF中的圖片的示例代碼

    這篇文章主要介紹了Java 添加、替換、刪除PDF中的圖片,本文通過示例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Quartz高可用定時(shí)任務(wù)的快速上手指南

    Quartz高可用定時(shí)任務(wù)的快速上手指南

    Quartz的分布式策略就是一種以數(shù)據(jù)庫(kù)作為邊界資源的并發(fā)策略,每個(gè)節(jié)點(diǎn)都遵守相同的操作規(guī)范,使得對(duì)數(shù)據(jù)庫(kù)的操作可以串行執(zhí)行,而不同名稱的調(diào)度器又可以互不影響的并行運(yùn)行,下面這篇文章主要介紹了Quartz高可用定時(shí)任務(wù)快速上手的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • Maven的生命周期與自定義插件實(shí)現(xiàn)方法

    Maven的生命周期與自定義插件實(shí)現(xiàn)方法

    Maven的生命周期就是對(duì)所有的構(gòu)建過程進(jìn)行抽象和統(tǒng)一。包含了項(xiàng)目的清理、初始化、編譯、測(cè)試、打包、集成測(cè)試、驗(yàn)證、部署和站點(diǎn)生成等幾乎所有的構(gòu)建步驟
    2022-12-12
  • 23種設(shè)計(jì)模式(3) java原型模式

    23種設(shè)計(jì)模式(3) java原型模式

    這篇文章主要為大家詳細(xì)介紹了23種設(shè)計(jì)模式之java原型模式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 最新評(píng)論