eclipse debug 多線程


     

以前用到過許多線程開發,對多線程開發也算是小有點心得,但一開始多線程開發的時候,碰到很多壁。但總得來說,有個好的工具總是能事半功倍。我用的工具是eclipse,在開發多線程時,其debug模式是能直接模擬多線程環境的,網上也有許多資料,但大多都不是很全。希望我能夠將自己的一些心得記錄下來,希望能幫助到還為多線程開發而糾結的朋友。

先寫個簡單的多線程測試用例:

package com.wxw.debug;

     

public class TestMain extends Thread {

     

    @Override

    public void run() {

        System.out.println("hello world");

    }

        

    public static void main(String[] args) {

        TestMain t1 = new TestMain();

        TestMain t2 = new TestMain();

        t1.start();

        t2.start();

    }

}

這段代碼,控制台打印出兩行

Hello world

接下來,將示范怎么樣使用debug模式進行一步步的執行,后面將逐步對知識進行應用擴展

  1. 斷點的位置

這里有個點需要注意,斷點的位置一定要正確,run方法或者run以后調用的方法里,否則的話,程序跑完了,debug模式里也只有一個主線程在跑,好了,直接看結果。

在這里我們看到了兩個線程已經起來了,在debug模式里也注明了Thread-0和Thread-1,在這里我再加段代碼來更明顯的顯示哪個線程執行到了這里。

加上這段代碼后,打印出來的結果就是

Thread-0 hello world

Thread-1 hello world

現在我需要將Thread-1這個線程先打印出來結果,也就是將線程可控,我想先執行哪個都行,怎么辦了?為了更加明顯,我多加幾個線程,總共5個線程,按先后順序打印出來,我是語言表達困難戶,直接看圖,圖為動態,有點大,請耐心等待

我想這個動態應該不用多解釋,也許有人會問這有什么用,這個用處可大了,我們可以控制哪個線程開始運行,哪個線程運行到某個點后,程序暫停在那里,然后其他程序再運行。最典型的例子就是單例模式在多線程下是否絕對安全(是否一定是單例),這里我也演示一下,線程不安全的單例模式代碼,摘自:http://www.blogjava.net/kenzhh/archive/2013/03/15/357824.html

public class Singleton {

    private static Singleton instance;

   

    private Singleton() {

    }

   

    public static Singleton getInstance() {

        if (instance == null) {

            System.out.println(instance);

            instance = new Singleton();

        }

        return instance;

    }

}

是否是單例,打印出引用地址就可以了,測試環境用兩個線程打印

正常情況下,應該打印出來兩個同樣的值,先直接run,不用debug模式,結果如下:

這一般情況下,是表現的單例,在大多數情況下,你有可能測試很多次的結果依然如此,但這段代碼確實在多線程情況下會出問題,怎么才能重現這個問題了,下面直接用圖演示:

最后的結果:

  com.wxw.debug.Singleton@1fc0f04

com.wxw.debug.Singleton@13ded59

這里可以看出,兩個結果不一樣,證明不是同一個對象。問題就這樣重現,是不是覺得這個工具很有用啊。

這篇文章不是講單例模式,舉的是一個典型的例子,主要講用debug模式解決多線程情況下的問題。我想,用debug模式,不僅僅用來解決問題,還能幫助我們理解一些知識點,這才達到了邊用邊學的好處。

   


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM