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

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

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Java信號(hào)量模型實(shí)際應(yīng)用手冊(cè)

Java信號(hào)量模型需要我們不斷的進(jìn)行學(xué)習(xí),在學(xué)習(xí)的時(shí)候會(huì)有不少的問(wèn)題阻礙著我們。下面我們就來(lái)看看同步鎖模型只是最簡(jiǎn)單的同步模型。同一時(shí)刻,只有一個(gè)線程能夠運(yùn)行同步代碼。

創(chuàng)新互聯(lián)技術(shù)團(tuán)隊(duì)十載來(lái)致力于為客戶提供成都網(wǎng)站制作、網(wǎng)站建設(shè)、成都品牌網(wǎng)站建設(shè)、營(yíng)銷型網(wǎng)站建設(shè)、搜索引擎SEO優(yōu)化等服務(wù)。經(jīng)過(guò)多年發(fā)展,公司擁有經(jīng)驗(yàn)豐富的技術(shù)團(tuán)隊(duì),先后服務(wù)、推廣了近1000家網(wǎng)站,包括各類中小企業(yè)、企事單位、高校等機(jī)構(gòu)單位。

有的時(shí)候,我們希望處理更加復(fù)雜的同步模型,比如生產(chǎn)者/消費(fèi)者模型、讀寫(xiě)同步模型等。這種情況下,同步鎖模型就不夠用了。我們需要一個(gè)新的模型。這就是我們要講述的Java信號(hào)量模型。#t#

Java信號(hào)量模型的工作方式如下:線程在運(yùn)行的過(guò)程中,可以主動(dòng)停下來(lái),等待某個(gè)Java信號(hào)量模型的通知;這時(shí)候,該線程就進(jìn)入到該信號(hào)量的待召(Waiting)隊(duì)列當(dāng)中;等到通知之后,再繼續(xù)運(yùn)行。

很多語(yǔ)言里面,同步鎖都由專門(mén)的對(duì)象表示,對(duì)象名通常叫Monitor。同樣,在很多語(yǔ)言中,Java信號(hào)量模型通常也有專門(mén)的對(duì)象名來(lái)表示,比如,Mutex,Semphore。

Java信號(hào)量模型要比同步鎖模型復(fù)雜許多。一些系統(tǒng)中,信號(hào)量甚至可以跨進(jìn)程進(jìn)行同步。另外一些信號(hào)量甚至還有計(jì)數(shù)功能,能夠控制同時(shí)運(yùn)行的線程數(shù)。

我們沒(méi)有必要考慮那么復(fù)雜的模型。所有那些復(fù)雜的模型,都是最基本的模型衍生出來(lái)的。只要掌握了最基本的信號(hào)量模型——“等待/通知”模型,復(fù)雜模型也就迎刃而解了。

我們還是以Java語(yǔ)言為例。Java語(yǔ)言里面的同步鎖和Java信號(hào)量模型概念都非常模糊,沒(méi)有專門(mén)的對(duì)象名詞來(lái)表示同步鎖和信號(hào)量,只有兩個(gè)同步鎖相關(guān)的關(guān)鍵字——volatile和synchronized。

這種模糊雖然導(dǎo)致概念不清,但同時(shí)也避免了Monitor、Mutex、Semphore等名詞帶來(lái)的種種誤解。我們不必執(zhí)著于名詞之爭(zhēng),可以專注于理解實(shí)際的運(yùn)行原理。

在Java語(yǔ)言里面,任何一個(gè)Object Reference都可以作為同步鎖。同樣的道理,任何一個(gè)Object Reference也可以作為Java信號(hào)量模型。

Object對(duì)象的wait()方法就是等待通知,Object對(duì)象的notify()方法就是發(fā)出通知。

具體調(diào)用方法為

(1)等待某個(gè)Java信號(hào)量模型的通知

public static final Object signal = new Object();

… f1() {

synchronized(singal) { // 首先我們要獲取這個(gè)信號(hào)量。這個(gè)信號(hào)量同時(shí)也是一個(gè)同步鎖

// 只有成功獲取了signal這個(gè)信號(hào)量兼同步鎖之后,我們才可能進(jìn)入這段代碼

signal.wait(); // 這里要放棄信號(hào)量。本線程要進(jìn)入signal信號(hào)量的待召(Waiting)隊(duì)列

// 可憐。辛辛苦苦爭(zhēng)取到手的Java信號(hào)量模型,就這么被放棄了

// 等到通知之后,從待召(Waiting)隊(duì)列轉(zhuǎn)到就緒(Ready)隊(duì)列里面

// 轉(zhuǎn)到了就緒隊(duì)列中,離CPU核心近了一步,就有機(jī)會(huì)繼續(xù)執(zhí)行下面的代碼了。

// 仍然需要把signal同步鎖競(jìng)爭(zhēng)到手,才能夠真正繼續(xù)執(zhí)行下面的代碼。命苦啊。

需要注意的是,上述代碼中的signal.wait()的意思。signal.wait()很容易導(dǎo)致誤解。signal.wait()的意思并不是說(shuō),signal開(kāi)始wait,而是說(shuō),運(yùn)行這段代碼的當(dāng)前線程開(kāi)始wait這個(gè)signal對(duì)象,即進(jìn)入signal對(duì)象的待召(Waiting)隊(duì)列。

(2)發(fā)出某個(gè)Java信號(hào)量模型的通知

… f2() {

synchronized(singal) { // 首先,我們同樣要獲取這個(gè)信號(hào)量。同時(shí)也是一個(gè)同步鎖。

// 只有成功獲取了signal這個(gè)信號(hào)量兼同步鎖之后,我們才可能進(jìn)入這段代碼

signal.notify(); // 這里,我們通知signal的待召隊(duì)列中的某個(gè)線程。

// 如果某個(gè)線程等到了這個(gè)通知,那個(gè)線程就會(huì)轉(zhuǎn)到就緒隊(duì)列中

// 但是本線程仍然繼續(xù)擁有signal這個(gè)同步鎖,本線程仍然繼續(xù)執(zhí)行

// 嘿嘿,雖然本線程好心通知其他線程,

// 但是,本線程可沒(méi)有那么高風(fēng)亮節(jié),放棄到手的同步鎖

// 本線程繼續(xù)執(zhí)行下面的代碼

需要注意的是,signal.notify()的意思。signal.notify()并不是通知signal這個(gè)對(duì)象本身。而是通知正在等待signal信號(hào)量的其他線程。

以上就是Object的wait()和notify()的基本用法。

實(shí)際上,wait()還可以定義等待時(shí)間,當(dāng)線程在某Java信號(hào)量模型的待召隊(duì)列中,等到足夠長(zhǎng)的時(shí)間,就會(huì)等無(wú)可等,無(wú)需再等,自己就從待召隊(duì)列轉(zhuǎn)移到就緒隊(duì)列中了。

另外,還有一個(gè)notifyAll()方法,表示通知待召隊(duì)列里面的所有線程。這些細(xì)節(jié)問(wèn)題,并不對(duì)大局產(chǎn)生影響。


新聞標(biāo)題:Java信號(hào)量模型實(shí)際應(yīng)用手冊(cè)
文章網(wǎng)址:http://www.5511xx.com/article/dpcophi.html