java 線程中start方法與run方法的區(qū)別詳細(xì)介紹
線程中start方法與run方法的區(qū)別
在線程中,如果start方法依次調(diào)用run方法,為什么我們會(huì)選擇去調(diào)用start方法?或者在java線程中調(diào)用start方法與run方法的區(qū)別在哪里? 這兩個(gè)問(wèn)題是兩個(gè)非常流行的初學(xué)者級(jí)別的多線程面試問(wèn)題。當(dāng)一個(gè)Java程序員開(kāi)始學(xué)習(xí)線程的時(shí)候,他們首先會(huì)學(xué)著去繼承Thread類,重載run方法或者實(shí)現(xiàn)Runnable接口,實(shí)現(xiàn)run方法,然后調(diào)用Thread實(shí)例的start方法。但是當(dāng)他擁有一些經(jīng)驗(yàn)之后,他通過(guò)查看API文檔或者其他途徑會(huì)發(fā)現(xiàn)start方法內(nèi)部會(huì)調(diào)用run方法,但是我們中的很多人知道面試時(shí)被問(wèn)到的時(shí)候才會(huì)意識(shí)到這個(gè)問(wèn)題的重要性。在這個(gè)java教程里,我們將會(huì)明白java中開(kāi)啟線程的時(shí)候調(diào)用start方法和run方法的不同的地方
這篇文章是我們?cè)倨鹪贘ava多線程上發(fā)表的一些文章的后序部分,E.G. Difference between Runnable and Thread in Java AND How to solve Producer Consumer problem in Java using BlockingQueue.如果你還沒(méi)有讀過(guò)他們,你可能將會(huì)發(fā)現(xiàn)他們還是很有趣并且很有用的
在java線程中 start與run的不同
start與run方法的主要區(qū)別在于當(dāng)程序調(diào)用start方法一個(gè)新線程將會(huì)被創(chuàng)建,并且在run方法中的代碼將會(huì)在新線程上運(yùn)行,然而在你直接調(diào)用run方法的時(shí)候,程序并不會(huì)創(chuàng)建新線程,run方法內(nèi)部的代碼將在當(dāng)前線程上運(yùn)行。大多數(shù)情況下調(diào)用run方法是一個(gè)bug或者變成失誤。因?yàn)檎{(diào)用者的初衷是調(diào)用start方法去開(kāi)啟一個(gè)新的線程,這個(gè)錯(cuò)誤可以被很多靜態(tài)代碼覆蓋工具檢測(cè)出來(lái),比如與fingbugs. 如果你想要運(yùn)行需要消耗大量時(shí)間的任務(wù),你最好使用start方法,否則在你調(diào)用run方法的時(shí)候,你的主線程將會(huì)被卡住。另外一個(gè)區(qū)別在于,一但一個(gè)線程被啟動(dòng),你不能重復(fù)調(diào)用該thread對(duì)象的start方法,調(diào)用已經(jīng)啟動(dòng)線程的start方法將會(huì)報(bào)IllegalStateException異常, 而你卻可以重復(fù)調(diào)用run方法
下面是start方法和run方法的demo
線程中的任務(wù)是打印線程傳入的String值 已經(jīng)當(dāng)前線程的名字
這里可以明確的看到兩者的區(qū)別
public class DiffBewteenStartAndRun { public static void main(String args[]) { System.out.println(Thread.currentThread().getName()); // creating two threads for start and run method call Thread startThread = new Thread(new Task("start")); Thread runThread = new Thread(new Task("run")); startThread.start(); // calling start method of Thread - will execute in // new Thread runThread.run(); // calling run method of Thread - will execute in // current Thread } /* * Simple Runnable implementation */ private static class Task implements Runnable { private String caller; public Task(String caller) { this.caller = caller; } @Override public void run() { System.out.println("Caller: " + caller + " and code on this Thread is executed by : " + Thread.currentThread().getName()); } } }
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
使用RocketMQTemplate發(fā)送帶tags的消息
這篇文章主要介紹了使用RocketMQTemplate發(fā)送帶tags的消息,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07SpringMVC文件上傳原理及實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了SpringMVC文件上傳原理及實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07java中continue和break區(qū)別詳細(xì)解析
break和continue都是跳轉(zhuǎn)語(yǔ)句,它們將程序的控制權(quán)轉(zhuǎn)移到程序的另一部分,下面這篇文章主要給大家介紹了關(guān)于java中continue和break區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-11-11JFinal實(shí)現(xiàn)偽靜態(tài)的方法
JFinal 是基于 Java 語(yǔ)言的極速 WEB + ORM 框架,其核心設(shè)計(jì)目標(biāo)是開(kāi)發(fā)迅速、代碼量少、學(xué)習(xí)簡(jiǎn)單、功能強(qiáng)大、輕量級(jí)、易擴(kuò)展、Restful。這篇文章主要介紹了JFinal實(shí)現(xiàn)偽靜態(tài),需要的朋友可以參考下2018-04-04通過(guò)一個(gè)map替換字符串中指定的字符變量方法
下面小編就為大家?guī)?lái)一篇通過(guò)一個(gè)map替換字符串中指定的字符變量方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03java實(shí)現(xiàn)寫(xiě)入并保存txt文件的代碼詳解
在本篇文章里小編給大家整理了關(guān)于java實(shí)現(xiàn)寫(xiě)入并保存txt文件的代碼實(shí)例內(nèi)容,需要的朋友們可以參考學(xué)習(xí)下。2020-02-02