java多線程實(shí)例項(xiàng)目 多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫(xiě),到底要不要加鎖?
多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫(xiě),到底要不要加鎖?下面簡(jiǎn)要解釋一下原因:鎖定是因?yàn)椴僮鞑皇窃拥摹W屛覀冇貌僮饕粊?lái)解釋它。看下面兩個(gè)圖。我這個(gè)操作需要看上面的第二個(gè)圖,你能很清
多個(gè)線程可以讀一個(gè)變量,只有一個(gè)線程可以對(duì)這個(gè)變量進(jìn)行寫(xiě),到底要不要加鎖?
下面簡(jiǎn)要解釋一下原因:
鎖定是因?yàn)椴僮鞑皇窃拥?。讓我們用操作一?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)存同步,以確保其他線程可以立即看到它。
java多線程在互聯(lián)網(wǎng)公司的應(yīng)用場(chǎng)景是什么?
Java語(yǔ)言的一個(gè)重要特性是它支持多線程。多線程技術(shù)是Java的一種先進(jìn)技術(shù),它涉及到操作系統(tǒng)的知識(shí),接近于系統(tǒng)級(jí)。對(duì)于普通程序員來(lái)說(shuō),他們很少碰它。目前,在javaee(原始J2EE)的相關(guān)框架中,盡量避免使用線程。程序員最理想的狀態(tài)是專(zhuān)注于業(yè)務(wù)邏輯,而不是每天思考如何編寫(xiě)線程。最典型的應(yīng)用程序,如tomcat、tomcat,是多線程的,數(shù)百個(gè)客戶機(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ì)等待串行處理,因此客戶端根本無(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資源。