本篇內(nèi)容介紹了“Java并發(fā)編程的原則和技巧是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
成都創(chuàng)新互聯(lián)長(zhǎng)期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為綏德企業(yè)提供專(zhuān)業(yè)的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),綏德網(wǎng)站改版等技術(shù)服務(wù)。擁有10多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。
為什么需要并發(fā)編程?
并發(fā)編程幫助我們把做什么和什么時(shí)候做分開(kāi),可以明顯的改進(jìn)應(yīng)用程序的吞吐量和機(jī)構(gòu)。當(dāng)然不僅如此,往往在用到并發(fā)編程的時(shí)候有多重原因。例如業(yè)務(wù)需求、性能優(yōu)化需要、可簡(jiǎn)化任務(wù)調(diào)度、并行程序在多核心CPU有優(yōu)勢(shì)。
當(dāng)然這期間也會(huì)存在一些注意事項(xiàng),會(huì)對(duì)并發(fā)編程產(chǎn)生一定的誤解,例如并發(fā)并非總能改進(jìn)性能,在發(fā)在CPU有很多空閑時(shí)間的時(shí)候可以明顯改進(jìn)程序的性能,但是線程數(shù)量較多,頻繁的調(diào)度切換反而會(huì)降低系統(tǒng)的性能。
因此我們應(yīng)該客觀的認(rèn)識(shí)并發(fā)編程。例如編寫(xiě)并發(fā)程序必然會(huì)在代碼上增加額外的開(kāi)銷(xiāo);正確的并發(fā)是非常復(fù)雜的,即使對(duì)于簡(jiǎn)單的問(wèn)題;并發(fā)中的缺陷因?yàn)椴灰字匦乱膊蝗菀妆话l(fā)現(xiàn);并發(fā)往往需要對(duì)設(shè)計(jì)策略從根本上上進(jìn)行修改。
并發(fā)編程的原則和技巧
1、單一職責(zé)原則。分離并發(fā)相關(guān)代碼和其他代碼。
2、限制數(shù)據(jù)作用域。兩個(gè)線程修改共享對(duì)象的同一字段時(shí)可能會(huì)相互干擾,導(dǎo)致不可預(yù)期的行為,解決方案之一是構(gòu)造臨界區(qū),但是必須限制臨界區(qū)的數(shù)量。
3、使用數(shù)據(jù)副本。數(shù)據(jù)副本是避免共享數(shù)據(jù)的好方法,復(fù)制出來(lái)的對(duì)象只是以只讀的方式對(duì)待。
4、線程應(yīng)盡可能獨(dú)立。讓線程存在于自己的世界中,不與其他線程共享數(shù)據(jù)。
“Java并發(fā)編程的原則和技巧是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!