在一開(kāi)始接觸Java的時(shí)候我們沒(méi)有很注意Java語(yǔ)言規(guī)范,其實(shí)這是不對(duì)的。下面我們就來(lái)看看開(kāi)始執(zhí)行Java語(yǔ)言規(guī)范程序后,至少會(huì)有一個(gè)線程開(kāi)始操作,有操作的是被稱(chēng)為主線程的線程,主線程執(zhí)行輸入類(lèi)的main()。當(dāng)main()里的所有處理均結(jié)束后,則主線程也同時(shí)結(jié)束。
當(dāng)應(yīng)用程序的規(guī)模大到一定程度,程序里的多線程會(huì)以每種形式存在。以下是幾個(gè)常見(jiàn)的范例:
1) GUI應(yīng)用程序。
2) 比較花費(fèi)時(shí)間的I/O處理。
3) 多個(gè)客戶(hù)端。
如欲啟動(dòng)線程時(shí),有下列兩種方法:
1) 利用Thread類(lèi)的子類(lèi)的實(shí)例,啟動(dòng)線程。
2) 利用Runnable接口的實(shí)現(xiàn)類(lèi)的實(shí)例,啟動(dòng)線程。
要注意的是,“Thread的實(shí)例”和“線程本身”是兩個(gè)不同的部分。即使建立了Thread的實(shí)例,也還沒(méi)有啟動(dòng)線程,而且就算線程已經(jīng)結(jié)束,Thread實(shí)例也不會(huì)就這樣消失。
建立一個(gè)實(shí)現(xiàn)Runnable接口的類(lèi),將該類(lèi)的實(shí)例傳給Thread的構(gòu)造函數(shù),調(diào)用start()...,這就是利用Runnable接口來(lái)啟動(dòng)線程的方法。
記。簾o(wú)論哪種方式,啟動(dòng)新線程的方法永遠(yuǎn)是Thread類(lèi)的start()。
利用Thread類(lèi)的sleep()可以暫停線程的執(zhí)行。執(zhí)行下面的語(yǔ)句時(shí),即可讓當(dāng)前的線程(執(zhí)行此語(yǔ)句的線程)暫時(shí)停止越1000ms。
Thread.sleep(1000);
當(dāng)實(shí)例方法加上關(guān)鍵字synchronized聲明之后,就可以只讓一個(gè)線程操作某類(lèi)實(shí)例的這類(lèi)方法。“讓一個(gè)線程操作”并不是說(shuō)只能讓某一個(gè)特定的線程操作而已,而是指一次只能讓一個(gè)線程執(zhí)行。這種方法稱(chēng)為synchronized方法(同步方法)。
synchronized實(shí)例方法是使用this鎖定去做線程的共享互斥。synchronized類(lèi)方法是使用該類(lèi)的類(lèi)對(duì)象的鎖定去做線程的共享互斥。
Java語(yǔ)言規(guī)范線程的協(xié)調(diào)(這三種方法執(zhí)行的前提是執(zhí)行線程手中有obj的鎖):
1) obj.wait()是把現(xiàn)在的線程放到obj的wait set;
2) obj.notify()是從obj的wait set里喚醒一個(gè)線程;
3) obj.notifyAll()是喚醒所有在obj的wait set里的線程。
被喚醒的線程只是處于等鎖狀態(tài)(但已經(jīng)不再wait set中了),當(dāng)時(shí)的obj的鎖還掌握在執(zhí)行notify()或notifyAll()的線程手上。當(dāng)喚醒的線程得到鎖之后,將從wait()之后繼續(xù)執(zhí)行。Introduction
Java語(yǔ)言規(guī)范多線程程序的評(píng)量標(biāo)準(zhǔn)
安全性--不損壞對(duì)象。
生存性--進(jìn)行必要的處理。(liveness)
復(fù)用性--可再利用類(lèi)。
性 能--能快速、大量進(jìn)行處理。
Single Threaded Execution - 能通過(guò)這座橋的,只有一個(gè)人
Single Threaded Execution是指“以一個(gè)線程執(zhí)行”的意思。就象細(xì)獨(dú)木橋只能允許一個(gè)人通過(guò)一樣,這個(gè)模式用來(lái)限制只讓一個(gè)線程運(yùn)行。
在Single Threaded Execution Pattern中,我們將unsafeMethod加以防衛(wèi),限制同時(shí)只能有一個(gè)線程可以調(diào)用它(加上synchronized)。這個(gè)必須讓單線程執(zhí)行的程序范圍,我們稱(chēng)為“臨界區(qū)”(critical section)。
使用Single Threaded Execution Pattern時(shí),可能會(huì)有發(fā)生死鎖(deadlock)的危險(xiǎn)。
當(dāng)SharedResource的字段開(kāi)放給子類(lèi)訪問(wèn)時(shí),可能會(huì)因?yàn)樽宇?lèi)寫(xiě)出unsafeMethod而導(dǎo)致喪失安全性。
synchronized方法和synchronized塊,無(wú)論碰到return或是異常,都會(huì)確實(shí)解除鎖定。
結(jié)論,Java語(yǔ)言規(guī)范中:
1) 基本類(lèi)型、引用類(lèi)型的指定、引用是原子的操作。
2) 但是long和double的指定、引用是可以分割的。
3) 要在線程間共享long或double的字段時(shí),必須在synchronized中操作,或是聲明成volatile。
相關(guān)推薦:計(jì)算機(jī)等級(jí)考試二級(jí)JAVA考前密卷北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |