日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
Java虛擬機(jī)對(duì)鎖優(yōu)化所做的努力

Java 虛擬機(jī)對(duì)鎖優(yōu)化所做的努力

作者:佚名 2018-09-11 14:24:34
云計(jì)算
虛擬化 作為一款公用平臺(tái),JDK 本身也為并發(fā)程序的性能絞盡腦汁,在 JDK 內(nèi)部也想盡一切辦法提供并發(fā)時(shí)的系統(tǒng)吞吐量。這里,我將向大家簡(jiǎn)單介紹幾種 JDK 內(nèi)部的 "鎖" 優(yōu)化策略。

 作為一款公用平臺(tái),JDK 本身也為并發(fā)程序的性能絞盡腦汁,在 JDK 內(nèi)部也想盡一切辦法提供并發(fā)時(shí)的系統(tǒng)吞吐量。這里,我將向大家簡(jiǎn)單介紹幾種 JDK 內(nèi)部的 "鎖" 優(yōu)化策略。

1、 鎖偏向

鎖偏向是一種針對(duì)加鎖操作的優(yōu)化手段。

如果一個(gè)線程獲得了鎖,那么鎖就進(jìn)入偏向模式。當(dāng)這個(gè)線程再次請(qǐng)求鎖時(shí),無(wú)須再做任何同步操作。這樣就節(jié)省了大量有關(guān)鎖申請(qǐng)的操作,從而提高了程序性能。

因此,對(duì)于幾乎沒(méi)有鎖競(jìng)爭(zhēng)的場(chǎng)合,偏向鎖有比較紅啊的優(yōu)化效果,因?yàn)檫B續(xù)多次極有可能是同一個(gè)線程請(qǐng)求相同的鎖。而對(duì)于鎖競(jìng)爭(zhēng)比較激烈的場(chǎng)合,其效果不佳。因?yàn)樵诟?jìng)爭(zhēng)激烈的場(chǎng)合,最有可能的情況是每次都是不同的線程來(lái)請(qǐng)求相同的鎖。點(diǎn)擊這里了解幾種常見(jiàn)的鎖。

2、 輕量級(jí)鎖

如果偏向鎖失敗,即上一個(gè)請(qǐng)求的鎖的線程和這個(gè)線程不是同一個(gè)。偏向鎖失敗意味者不能避免做同步操作。此時(shí),虛擬機(jī)并不會(huì)立即掛起線程。他會(huì)使用一種成為輕量級(jí)鎖的優(yōu)化手段。

輕量級(jí)鎖的操作也很方便,它只是簡(jiǎn)單地將對(duì)象頭部作為指針,指向蚩尤鎖的線程堆棧的內(nèi)部,來(lái)判斷一個(gè)線程是否持有對(duì)象鎖。 如果線程獲得輕量級(jí)鎖成功,則可以順利進(jìn)入臨界區(qū)。如果輕量級(jí)鎖失敗,則表示其他線程搶先爭(zhēng)奪了鎖,那么當(dāng)前線程的鎖請(qǐng)求就會(huì)膨脹為重量級(jí)鎖。點(diǎn)擊這里了解幾種常見(jiàn)的鎖。

3、 自選鎖

鎖膨脹后,虛擬機(jī)為了避免線程真實(shí)地在操作系統(tǒng)層面掛起,虛擬機(jī)還會(huì)在做***的努力–自選鎖。由于當(dāng)前線程暫時(shí)無(wú)法獲得鎖,但是什么時(shí)候可以獲得鎖是一個(gè)未知數(shù)。也許在CPU幾個(gè)時(shí)鐘周期后,就可以得到鎖。如果這樣,簡(jiǎn)單粗暴的掛起線程可能是一種得不償失的操作,因此系統(tǒng)會(huì)進(jìn)行一次賭注:它會(huì)假設(shè)在不久的將來(lái),線程可以得到這把鎖。

因此虛擬機(jī)讓當(dāng)前線程做個(gè)空循環(huán),在經(jīng)過(guò)若干次循環(huán)后,如果可以得到鎖,那么就順利進(jìn)入臨界區(qū)。如果還不能得到鎖,才會(huì)真實(shí)地將線程在操作系統(tǒng)層面掛起。

4、 鎖消除

鎖消除是一種更徹底的鎖優(yōu)化。Java虛擬機(jī)在JIT編譯時(shí),通過(guò)對(duì)運(yùn)行上下文的掃描,去除不可能存在共享資源競(jìng)爭(zhēng)的鎖。通過(guò)鎖消除,可以節(jié)省毫無(wú)意義的請(qǐng)求鎖時(shí)間。

下面這種這種情況,我們使用vector, 而vector內(nèi)部使用了synchronize請(qǐng)求鎖。

  
 
 
  1. public String []  createStrings(){ 
  2.     Vector  v= new Vector(); 
  3.     for(int i=0;i<100;i++){ 
  4.         v.add(Integer.toString(i)); 
  5.     } 
  6.     return v.toArray(new String[]{}); 

由于V只在函數(shù) createStrnigs 中使用,因此它只是一個(gè)單純的局部變量。局部變量是在線程棧上分配的,屬于線程私有額數(shù)據(jù),因此不可能被其他線程訪問(wèn)。所以,在這種情況下,Vector內(nèi)部所有加鎖同步都是沒(méi)有必要的。如果虛擬機(jī)檢測(cè)到這種情況,就會(huì)將這些無(wú)用的鎖操作去除。點(diǎn)擊這里了解幾種常見(jiàn)的鎖。

鎖消除涉及的一項(xiàng)關(guān)鍵技術(shù)為逃逸分析。所謂逃逸分析就是觀察某一個(gè)變量是否會(huì)逃出某一個(gè)作用域。在本例中,變量v顯然沒(méi)有逃出createString 函數(shù)之外。以此為基礎(chǔ),虛擬機(jī)才可以大膽的將v內(nèi)部的加鎖操作去除。如果createStrings 返回的不是String數(shù)組,而是v本身,那么就認(rèn)為變量v逃逸出了當(dāng)前函數(shù),也就是說(shuō)v有可能被其他線程訪問(wèn)。如是這樣,虛擬機(jī)就不能消除v中的鎖操作。

逃逸分析必須在 -server 模式下進(jìn)行,可以使用 -XX:DoEscapeAnalysis 參數(shù)打開(kāi)逃逸分析,使用 -XX:+EliminateLocks 參數(shù)可以打開(kāi)鎖消除。


網(wǎng)頁(yè)名稱(chēng):Java虛擬機(jī)對(duì)鎖優(yōu)化所做的努力
轉(zhuǎn)載注明:http://m.5511xx.com/article/djicgcg.html