| 時(shí)間:2006-08-08 作者:axman 瀏覽次數: 3331 本文關(guān)鍵字:Java, 多線(xiàn)程, 線(xiàn)程, 線(xiàn)程對象, 單線(xiàn)程, go deep into java |
|

[寫(xiě)在前面]
隨著(zhù)計算機技術(shù)的發(fā)展,編程模型也越來(lái)越復雜多樣化。但多線(xiàn)程編程模型是目前計算機系統架構的最終模型。隨著(zhù)CPU主頻的不斷攀升,X86架構的硬件已經(jīng)成為瓶,在這種架構的CPU主頻最高為4G。事實(shí)上目前3.6G主頻的CPU已經(jīng)接近了頂峰。
如果不能從根本上更新當前CPU的架構(在很長(cháng)一段時(shí)間內還不太可能),那么繼續提高CPU性能的方法就是超線(xiàn)程CPU模式。那么,作業(yè)系統、應用程序要發(fā)揮CPU的最大性能,就是要改變到以多線(xiàn)程編程模型為主的并行處理系統和并發(fā)式應用程序。
所以,掌握多線(xiàn)程編程模型,不僅是目前提高應用性能的手段,更是下一代編程模型的核心思想。多線(xiàn)程編程的目的,就是"最大限度地利用CPU資源",當某一線(xiàn)程的處理不需要占用CPU而只和I/O,OEMBIOS等資源打交道時(shí),讓需要占用CPU資源的其它線(xiàn)程有機會(huì )獲得CPU資源。從根本上說(shuō),這就是多線(xiàn)程編程的最終目的。
[第一需要弄清的問(wèn)題]
如同程序和進(jìn)程的區別,要掌握多線(xiàn)程編程,第一要弄清的問(wèn)題是:線(xiàn)程對象和線(xiàn)程的區別。
線(xiàn)程對象是可以產(chǎn)生線(xiàn)程的對象。比如在java平臺中Thread對象,Runnable對象。線(xiàn)程,是指正在執行的一個(gè)指點(diǎn)令序列。在java平臺上是指從一個(gè)線(xiàn)程對象的start()開(kāi)始,運行run方法體中的那一段相對獨立的過(guò)程。
鑒于作者的水平,無(wú)法用更確切的詞匯來(lái)描述它們的定義。但這兩個(gè)有本質(zhì)區別的概念請初學(xué)者細細體會(huì ),隨著(zhù)介紹的深入和例程分析的增加,就會(huì )慢慢明白它們所代表的真實(shí)含義。
天下難事必始于易,天下大事必始于細。
讓我們先從最簡(jiǎn)單的"單線(xiàn)程"來(lái)入手:(1)帶引號說(shuō)明只是相對而言的單線(xiàn)程,(2)基于java。
class BeginClass{public static void main(String[] args){for(int i=0;i<100;i++)System.out.println("Hello,World!");}}如果我們成功編譯了該java文件,然后在命令行上敲入:
java BeginClass
現在發(fā)生了什么呢?每一個(gè)java程序員,從他開(kāi)始學(xué)習java的第一分鐘里都會(huì )接觸到這個(gè)問(wèn)
題,但是,你知道它到底發(fā)生發(fā)什么?
JVM進(jìn)程被啟動(dòng),在同一個(gè)JVM進(jìn)程中,有且只有一個(gè)進(jìn)程,就是它自己。然后在這個(gè)JVM環(huán)境中,所有程序的運行都是以線(xiàn)程來(lái)運行。JVM最先會(huì )產(chǎn)生一個(gè)主線(xiàn)程,由它來(lái)運行指定程序的入口點(diǎn)。在這個(gè)程序中,就是主線(xiàn)程從main方法開(kāi)始運行。當main方法結束后,主線(xiàn)程運行完成。JVM進(jìn)程也隨之退出。
我們看到的是一個(gè)主線(xiàn)程在運行main方法,這樣的只有一個(gè)線(xiàn)程執行程序邏輯的流程我們稱(chēng)
之為單線(xiàn)程。這是JVM提供給我們的單線(xiàn)程環(huán)境,事實(shí)上,JVM底層還至少有垃圾回收這樣的后臺線(xiàn)程以及其它非java線(xiàn)程,但這些線(xiàn)程對我們而言不可訪(fǎng)問(wèn),我們只認為它是單線(xiàn)程的。
主線(xiàn)程是JVM自己?jiǎn)?dòng)的,在這里它不是從線(xiàn)程對象產(chǎn)生的。在這個(gè)線(xiàn)程中,它運行了main方法這個(gè)指令序列。理解它,但它沒(méi)有更多可以研究的內容。
[接觸多線(xiàn)程]
class MyThread extends Thread{public void run(){System.out.println("Thread say:Hello,World!");}}public class MoreThreads{public static void main(String[] args){new MyThread();new MyThread().start();System.out.println("Main say:Hello,World");}}執行這個(gè)程序,main方法第一行產(chǎn)生了一個(gè)線(xiàn)程對象,但并沒(méi)有線(xiàn)程啟動(dòng)。
main方法第二行產(chǎn)生了一個(gè)線(xiàn)程對象,并啟動(dòng)了一個(gè)線(xiàn)程。
main方法第三行,產(chǎn)生并啟動(dòng)一個(gè)線(xiàn)程后,主線(xiàn)程自己也繼續執行其它語(yǔ)句。
我們先不研究Thread對象的具體內容,稍微來(lái)回想一下上面的兩個(gè)概念,線(xiàn)程對象和線(xiàn)程。在JAVA中,線(xiàn)程對象是JVM產(chǎn)生的一個(gè)普通的Object子類(lèi)。而線(xiàn)程是CPU分配給這個(gè)對象的一個(gè)運行過(guò)程。我們說(shuō)的這個(gè)線(xiàn)程在干什么,不是說(shuō)一個(gè)線(xiàn)程對象在干什么,而是這個(gè)運行過(guò)程在干什么。如果一時(shí)想不明白,不要急,但你要記得它們不是一回事就行了。
累了吧?為不么不繼續了?
基于這種風(fēng)格來(lái)介紹多線(xiàn)程,并不是每個(gè)人都喜歡和接受的,如果你不喜歡,正好不浪費你的時(shí)間了,而如果你接受的話(huà),那就看下一節吧。
轉載自dev2dev網(wǎng)友axman的go deep into java專(zhuān)欄。
一個(gè)男人.
一個(gè)寫(xiě)程序的男人.
一個(gè)寫(xiě)程序并正在從程序中尋找快樂(lè )的男人.
一個(gè)寫(xiě)程序并正在從程序中尋找快樂(lè )并把快樂(lè )傳遞給大家的男人.
一個(gè)書(shū)生.
一個(gè)寂寞的書(shū)生.
一個(gè)寂寞的梅香竹影下敲聲寫(xiě)韻的書(shū)生.
一個(gè)寂寞的梅香竹影下敲聲寫(xiě)韻晨鐘暮鼓中逸氣揚劍的書(shū)生.
那個(gè)男人是位書(shū)生。沒(méi)有人知道他的姓名,居無(wú)定所,行無(wú)定蹤,亦耕變讀,或漁或樵。
所以有人叫他樵夫(Axman),有人叫他漁郎(fisher)。
聯(lián)系客服