java并發(fā)編程是java程序設(shè)計語言的一塊重點,在大部分的業(yè)務(wù)場景中都需要并發(fā)編程。
專注于為中小企業(yè)提供網(wǎng)站建設(shè)、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)瓊結(jié)免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
比如:并發(fā)的去處理http請求,這樣就可以使得一臺機器同時處理多個請求,大大提高業(yè)務(wù)的響應(yīng)效率,從而使用用戶體驗更加流暢。
java如何并發(fā)編程,要注意以下幾個方面:
1、java語言中的多線程操作:創(chuàng)建和啟動線程的幾種方式。
2、共享變量的同步問題,要保證線程安全,辨別哪些變量是線程安全的、那些變量是線程不安全的,對于不安全的變量我們要想辦法讓其同步,一般也就是加鎖。
3、線程鎖:包括方法鎖和synchronized塊的使用。
接下來就詳細說一下這幾個方面。
首先說創(chuàng)建線程的方式:一般有兩種方式
定義一個線程類:實現(xiàn)Runnable接口、或者繼承Thread,推薦是實現(xiàn)接口的方式。
啟動線程的方式:
第一種:new Thread()的方式。
創(chuàng)建好的線程,然后通過new的方式啟動線程,因為創(chuàng)建方式的不同,他們啟動的方式也略微有些差別。
第二種:通過線程池的方式啟動線程。JavaAPI提供了線程池技術(shù),可以用池的原理,
去管理線程,池的技術(shù)在java中很常見,比如數(shù)據(jù)庫連接池等。
具體細節(jié)可以參考如下的連接:
共享變量的問題:要明白什么變量最有可能出現(xiàn)線程安全問題。沒錯就是靜態(tài)變量,靜態(tài)變量
相當于C語言的全局變量,如果是public類型,誰都可以修改,所以這個時候就會出現(xiàn)
變量的線程安全問題。當然了私有變量也可能出現(xiàn)線程安全問題。
具體細節(jié)可以參考如下的連接:
主要來說一下線程鎖的兩種方式:
(1)首先定義一個MyBusiness類,此類中頂一個一個靜態(tài)變量i,和一個靜態(tài)方法,靜態(tài)方法的功能是讓i加1。
(2)然后定義一個線程類MyThread2,run方法中先讓線程sleep 2毫秒,然后執(zhí)行加1操作。
(3)定義測試類,測試類創(chuàng)建6000個MyThread2線程,然后sleep 1秒鐘,執(zhí)行輸出,顯示i的值。
(4)結(jié)果:從結(jié)果可以看出,此時出現(xiàn)了線程安全問題,就是說某些線程在加1操作時取到了臟數(shù)據(jù),即
在某一個時間點,多個線程同時取到了某個相同的i值,然后去修改,結(jié)果導(dǎo)致在這幾個線程中,只有最后一個
修改生效,而其他的則被覆蓋掉了。
(5)解決方案一:方法鎖,給add方法加鎖,表示同一時間只能有一個方法的調(diào)用被允許運行,其他的線程等待鎖的釋放。
再次運行,發(fā)現(xiàn)變成了6000就是正確的了。
(6)解決方案二:synchronized代碼塊,我們重新定義一個方法add1,然后用synchronized代碼塊鎖上MyBusiness類,
表示同一時間只能有一個線程操作MyBusiness類,其他線程必須等待鎖的釋放。
(7)查看結(jié)果,也得到了正確的輸出。