開(kāi)發(fā)中哪里用到多線程 實(shí)際工作中,什么場(chǎng)景會(huì)用到多線程開(kāi)發(fā)?
最典型的應(yīng)用程序,如tomcat、tomcat,是多線程的,數(shù)百個(gè)客戶(hù)機(jī)訪問(wèn)同一個(gè)web應(yīng)用程序。在Tomcat訪問(wèn)之后,隨后的處理被拋出到一個(gè)新線程。新線程最終被調(diào)用到我們的servlet程序,比如
最典型的應(yīng)用程序,如tomcat、tomcat,是多線程的,數(shù)百個(gè)客戶(hù)機(jī)訪問(wèn)同一個(gè)web應(yīng)用程序。在Tomcat訪問(wèn)之后,隨后的處理被拋出到一個(gè)新線程。新線程最終被調(diào)用到我們的servlet程序,比如doGet或doPost。
如果我們不使用多線程機(jī)制,當(dāng)數(shù)百人同時(shí)訪問(wèn)一個(gè)web應(yīng)用程序時(shí),Tomcat將不得不排隊(duì)等待串行處理,因此客戶(hù)端根本無(wú)法忍受這種訪問(wèn)速度。
還需要異步處理,您需要使用多線程。例如,任務(wù)a和任務(wù)B需要并行處理,單個(gè)線程只能串行處理。首先完成任務(wù)a,然后執(zhí)行任務(wù)B,如果要同時(shí)執(zhí)行多個(gè)任務(wù),必須為每個(gè)任務(wù)分配一個(gè)線程,然后通過(guò)Java虛擬機(jī)的線程調(diào)度,同時(shí)執(zhí)行多個(gè)任務(wù)。例如,如果您的CPU是多核的,那么您可以讓CPU執(zhí)行一個(gè)線程。如果只有一個(gè)CPU,底層基于分時(shí)復(fù)用的原則,每個(gè)線程根據(jù)時(shí)間片獲得CPU資源。
實(shí)際工作中,什么場(chǎng)景會(huì)用到多線程開(kāi)發(fā)?
下面簡(jiǎn)要說(shuō)明以下原因:
鎖定是因?yàn)椴僮鞑皇窃拥摹W屛覀冇貌僮饕粊?lái)解釋它??聪旅鎯蓚€(gè)圖。
我這個(gè)操作需要
看上面的第二個(gè)圖,你能很清楚地理解這個(gè)過(guò)程嗎?
鎖定是為了確保上述三個(gè)步驟是原子操作。
回到問(wèn)題上來(lái),只有一個(gè)線程要寫(xiě),沒(méi)有競(jìng)爭(zhēng),所以不需要鎖定。
但是,如果你看第一張圖片,因?yàn)橹鲀?nèi)存和本地內(nèi)存的存在
在一個(gè)線程寫(xiě)入后,其他線程無(wú)法立即看到它。這就是可見(jiàn)性問(wèn)題。
添加volatile關(guān)鍵字后,它將在操作后強(qiáng)制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。