国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

Java多線程學(xué)習(xí)筆記

2019-11-15 00:19:17
字體:
供稿:網(wǎng)友
java多線程學(xué)習(xí)筆記

概念部分:

1.并發(fā)和并行的區(qū)別:

  并發(fā) (Concurrency):一個處理器“同時”處理多個任務(wù)

  并行 (Parallelism):多個處理器 “同時”處理多個任務(wù)

2.多線程的優(yōu)點和缺點:

  多線程的優(yōu)點: 

    可并行處理任務(wù),減少單個任務(wù)的等待時間

    線程較進(jìn)程或子進(jìn)程系統(tǒng)開銷小

    線程間較容易共享資源

    多核情況下可充分利用CPU資源

  多線程的缺點:    訪問沖突    鎖競爭      –死鎖      –鎖粒度  上下文切換開銷  同步/內(nèi)存拷貝開銷

示意圖:

  • 新狀態(tài):一個新產(chǎn)生的線程從新狀態(tài)開始了它的生命周期。它保持這個狀態(tài)知道程序start這個線程。
  • 運行狀態(tài):當(dāng)一個新狀態(tài)的線程被start以后,線程就變成可運行狀態(tài),一個線程在此狀態(tài)下被認(rèn)為是開始執(zhí)行其任務(wù)
  • 就緒狀態(tài):當(dāng)一個線程等待另外一個線程執(zhí)行一個任務(wù)的時候,該線程就進(jìn)入就緒狀態(tài)。當(dāng)另一個線程給就緒狀態(tài)的線程發(fā)送信號時,該線程才重新切換到運行狀態(tài)。
  • 休眠狀態(tài):由于一個線程的時間片用完了,該線程從運行狀態(tài)進(jìn)入休眠狀態(tài)。當(dāng)時間間隔到期或者等待的時間發(fā)生了,該狀態(tài)的線程切換到運行狀態(tài)。
  • 終止?fàn)顟B(tài):一個運行狀態(tài)的線程完成任務(wù)或者其他終止條件發(fā)生,該線程就切換到終止?fàn)顟B(tài)

語法糖:

1.定義線程名字(ID)和循環(huán)數(shù)

//定義線程循環(huán)次數(shù)PRotected int countDown = 10;//可以在線程中設(shè)定ID并打印來區(qū)分各個線程private static int taskCount = 0;private final int id = taskCount++;while(countDown-- >0){}

2.獲取線程名稱

System.out.println(Thread.currentThread().getName()+":"+value);... Thread t1 = new Thread(us,"t1");

JVM部分:

關(guān)于鎖:

1.某個對象實例內(nèi),synchronized aMethod(){}可以防止多個線程同時訪問這個對象的synchronized方法(如果一個對象有多個synchronized方法,只要一個線程訪問了其中的一個synchronized方法,其它線程不能同時訪問這個對象中任何一個synchronized方法)。這時,不同的對象實例的synchronized方法是不相干擾的。也就是說,其它線程照樣可以同時訪問相同類的另一個對象實例中的synchronized方法;

《Tinking In Java》部分:

1.并發(fā)具有可論證的確定性,但是實際上具有不可確定性。

2.如果沒有任務(wù)會阻塞,那么在單處理器機(jī)器上使用并發(fā)就沒有任何意義。

3.某些編程語言被設(shè)計為可以將并發(fā)任務(wù)彼此隔離,這些語言通常被稱作函數(shù)型語言——erlang。

4.語法糖:while(countDown-- >0)、private final int id = taskCount++; 使用后置的++和--,可以進(jìn)行計數(shù)器加減的操作,方便又清晰。

5.各種執(zhí)行器(Executor):

  CachedThreadPool:一般首選,會創(chuàng)建于所需數(shù)量相同的線程。

  FixedThreadPool:事先分好好線程,限制了線程數(shù)量。

  SingleThreadExecutor就像是線程數(shù)量為1的FixedThreadPool(它提供了長期存活和并發(fā)保證,適合于某些特定任務(wù))。SingleThreadExecutor會序列化所有提交給它的任務(wù)。

6.如果希望任務(wù)完成時能返回值,用callable代替runnable接口。

資料:

http://blog.csdn.net/csh624366188/article/details/7318245


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 景宁| 托克逊县| 丰镇市| 天长市| 柳河县| 陵水| 奉化市| 武城县| 阳曲县| 淄博市| 太康县| 巨野县| 宁化县| 长宁区| 汉中市| 岳普湖县| 永州市| 吴旗县| 绍兴市| 莫力| 包头市| 汉寿县| 景洪市| 承德市| 玉林市| 山阴县| 浏阳市| 保康县| 沐川县| 呈贡县| 恩施市| 五华县| 土默特右旗| 甘肃省| 阳西县| 额敏县| 东丽区| 会昌县| 仙桃市| 南昌县| 禹城市|