java中thread線程start和run的區(qū)別
最近看到一個題目,代碼如下:
public static void main(String args[]) {
Thread t = new Thread() {
public void run() {
pong();
}
};
t.run();
System.out.println("ping");
}
static void pong() {
System.out.println("pong");
}
問,結果會輸出什么?
我運行了很多次,結果都是pong ping。后來終于發(fā)現了關鍵點所在,線程對象t,調用的不是start()方法,而是run()方法。后來我開斷點模式debug,發(fā)現調用run()方法,整個程序只有一個線程,而調用start()方法之后,程序就會多出一個線程。這時才有和主線程爭cpu,可能出現多種結果的情況,但由于下面輸出方法很快就被執(zhí)行了,所以基本上都是“ping pong”的輸出。
所以run()和start()的區(qū)別就是:
run()是Runnable接口中定義的一個方法,是為了讓客戶程序員在這個方法里寫自己的功能代碼的。直接調用和普通的類調用自己的成員方法是沒有任何區(qū)別的。
而start()則是線程開始運行的標志,當這個方法被調用后,程序中才會多出一個獨立的線程,接著便是執(zhí)行run()方法。
所以我覺得,自己要寫單獨的線程,最好還是繼承Thread來做,如果是實現接口的話,到主線程里,還是要new Thread(new YourRunnableClass())來調用,感覺很不方便。
相關文章
SpringBoot2.0.3打印默認數據源為 HikariDataSource (null)問題
這篇文章主要介紹了SpringBoot2.0.3打印默認數據源為 HikariDataSource (null)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10