java_多線程與并發(fā)編程總結

java_多線程與并發(fā)編程總結

ID:15322295

大小:56.00 KB

頁數:14頁

時間:2018-08-02

java_多線程與并發(fā)編程總結_第1頁
java_多線程與并發(fā)編程總結_第2頁
java_多線程與并發(fā)編程總結_第3頁
java_多線程與并發(fā)編程總結_第4頁
java_多線程與并發(fā)編程總結_第5頁
資源描述:

《java_多線程與并發(fā)編程總結》由會員上傳分享,免費在線閱讀,更多相關內容在教育資源-天天文庫。

1、Java多線程與并發(fā)編程總結??認識多任務、多進程、單線程、多線程  要認識多線程就要從操作系統(tǒng)的原理說起。  以前古老的DOS操作系統(tǒng)(V6.22)是單任務的,還沒有線程的概念,系統(tǒng)在每次只能做一件事情。比如你在copy東西的時候不能rename文件名。為了提高系統(tǒng)的利用效率,采用批處理來批量執(zhí)行任務。  現在的操作系統(tǒng)都是多任務操作系統(tǒng),每個運行的任務就是操作系統(tǒng)所做的一件事情,比如你在聽歌的同時還在用MSN和好友聊天。聽歌和聊天就是兩個任務,這個兩個任務是“同時”進行的。一個任務一般對應一個進程,也可能包含好幾個進程。比如運行的MSN就對應一個MSN的進程,如果你用的是windo

2、ws系統(tǒng),你就可以在任務管理器中看到操作系統(tǒng)正在運行的進程信息。  一般來說,當運行一個應用程序的時候,就啟動了一個進程,當然有些會啟動多個進程。啟動進程的時候,操作系統(tǒng)會為進程分配資源,其中最主要的資源是內存空間,因為程序是在內存中運行的。在進程中,有些程序流程塊是可以亂序執(zhí)行的,并且這個代碼塊可以同時被多次執(zhí)行。實際上,這樣的代碼塊就是線程體。線程是進程中亂序執(zhí)行的代碼流程。當多個線程同時運行的時候,這樣的執(zhí)行模式成為并發(fā)執(zhí)行?! 《嗑€程的目的是為了最大限度的利用CPU資源。  Java編寫程序都運行在在Java虛擬機(JVM)中,在JVM的內部,程序的多任務是通過線程來實現的。每

3、用java命令啟動一個java應用程序,就會啟動一個JVM進程。在同一個JVM進程中,有且只有一個進程,就是它自己。在這個JVM環(huán)境中,所有程序代碼的運行都是以線程來運行?! ∫话愠R姷腏ava應用程序都是單線程的。比如,用java命令運行一個最簡單的HelloWorld的Java應用程序時,就啟動了一個JVM進程,JVM找到程序程序的入口點main(),然后運行main()方法,這樣就產生了一個線程,這個線程稱之為主線程。當main方法結束后,主線程運行完成。JVM進程也隨即退出?! τ谝粋€進程中的多個線程來說,多個線程共享進程的內存塊,當有新的線程產生的時候,操作系統(tǒng)不分配新的內

4、存,而是讓新線程共享原有的進程塊的內存。因此,線程間的通信很容易,速度也很快。不同的進程因為處于不同的內存塊,因此進程之間的通信相對困難。  實際上,操作的系統(tǒng)的多進程實現了多任務并發(fā)執(zhí)行,程序的多線程實現了進程的并發(fā)執(zhí)行。多任務、多進程、多線程的前提都是要求操作系統(tǒng)提供多任務、多進程、多線程的支持?! ≡贘ava程序中,JVM負責線程的調度。線程調度是值按照特定的機制為多個線程分配CPU的使用權?! ≌{度的模式有兩種:分時調度和搶占式調度。分時調度是所有線程輪流獲得CPU使用權,并平均分配每個線程占用CPU的時間;搶占式調度是根據線程的優(yōu)先級別來獲取CPU的使用權。JVM的線程調度模

5、式采用了搶占式模式?! ∷^的“并發(fā)執(zhí)行”、“同時”其實都不是真正意義上的“同時”。眾所周知,CPU都有個時鐘頻率,表示每秒中能執(zhí)行cpu指令的次數。在每個時鐘周期內,CPU實際上只能去執(zhí)行一條(也有可能多條)指令。操作系統(tǒng)將進程線程進行管理,輪流(沒有固定的順序)分配每個進程很短的一段是時間(不一定是均分),然后在每個線程內部,程序代碼自己處理該進程內部線程的時間分配,多個線程之間相互的切換去執(zhí)行,這個切換時間也是非常短的。因此多任務、多進程、多線程都是操作系統(tǒng)給人的一種宏觀感受,從微觀角度看,程序的運行是異步執(zhí)行的?! ∮靡痪湓捵隹偨Y:雖然操作系統(tǒng)是多線程的,但CPU每一時刻只能做

6、一件事,和人的大腦是一樣的,呵呵。???????Java語言的多線程需要操作系統(tǒng)的支持?! ava虛擬機允許應用程序并發(fā)地運行多個執(zhí)行線程。Java語言提供了多線程編程的擴展點,并給出了功能強大的線程控制API?! ≡贘ava中,多線程的實現有兩種方式:  擴展java.lang.Thread類  實現java.lang.Runnable接口  每個線程都有一個優(yōu)先級,高優(yōu)先級線程的執(zhí)行優(yōu)先于低優(yōu)先級線程。每個線程都可以或不可以標記為一個守護程序。當某個線程中運行的代碼創(chuàng)建一個新Thread對象時,該新線程的初始優(yōu)先級被設定為創(chuàng)建線程的優(yōu)先級,并且當且僅當創(chuàng)建線程是守護線程時,新線程

7、才是守護程序?! ‘擩ava虛擬機啟動時,通常都會有單個非守護線程(它通常會調用某個指定類的main方法)。Java虛擬機會繼續(xù)執(zhí)行線程,直到下列任一情況出現時為止:  調用了Runtime類的exit方法,并且安全管理器允許退出操作發(fā)生?! 》鞘刈o線程的所有線程都已停止運行,無論是通過從對run方法的調用中返回,還是通過拋出一個傳播到run方法之外的異常。???擴展java.lang.Thread類  運行結果:  main線程運行開始!  

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯系客服。
3. 下載前請仔細閱讀文檔內容,確認文檔內容符合您的需求后進行下載,若出現內容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯系客服處理。