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