一、Java併發編程基礎概念

一、進程與線程

進程:
  進程是操做系統結構的基礎,是程序在一個數據集合上運行的過程,它是系統進行資源分配和調度的一個獨立單位。
線程:
  線程能夠理解爲是進程中獨立運行的子任務數據庫

進程與線程的聯繫與區別:安全

  • 一個程序的運行至少包含一個進程,一個進程至少有一個線程
  • 線程的劃分尺度要小於進程,使得多線程的併發性高
  • 進程在執行過程當中擁有獨立的內存單元,而多個線程共享內存,從而極大的提升了程序的運行效率

二、線程安全

  線程安全就是多個線程訪問同一個類,無論運行時環境採用何種調度方式或者這些線程如何交替運行,而且在主調代碼中不須要任何額外的同步或協同,這個類都能表現出正確的行爲,那麼就程這個類是線程安全的。多線程

三、同步和異步

同步和異步是針對方法調用而言的
同步是指方法調用會等待方法返回,方法返回後才能繼續往下執行。
異步是指方法調用會當即返回,並繼續向下執行,可是異步調用當即返回並不表示這個調用請求處理完成,而是會在後臺起一個線程去執行。併發

四、並行與併發

併發:多個線程搶佔同一CPU時間片
並行:不一樣的CPU同時執行不一樣的線程異步

五、臨界區

臨界區用來表示一種公共資源。能夠被多線程使用,可是一次只能一個線程使用它,一旦臨界區被佔用,其餘線程要想使用臨界區資源,則只能進入阻塞等待隊列。操作系統

六、阻塞與非阻塞

阻塞和非阻塞一般用來形容多線程間的相互影響。
若是一個線程佔用了臨界區資源,那麼其餘全部須要這個資源的線程就會在這個臨界區的阻塞隊列中等待,等待就會致使線程掛起,致使阻塞。若是佔用這個臨界區資源的線程一直不釋放資源,那麼全部阻塞在這個臨界區的線程都不能進行工做。
而非阻塞是多個線程同時進入臨界區。線程

七、死鎖

死鎖是指兩個或者多個線程相互持有對方須要的資源,致使這些線程處於等待狀態,沒法繼續前行
死鎖產生的必要條件:隊列

  • 互持條件:一個資源只能被一個進程佔用
  • 請求和保持條件:一個進程因請求被佔用的資源發生阻塞時,對已得到資源保持不放
  • 不剝奪條件:任何一個資源在沒被該進程釋放以前,任何其餘線程都沒法對他剝奪佔用
  • 循環等待條件:當發生死鎖時,所等待的資源必然會造成一個環路。形成永久阻塞。

避免死鎖的幾個方式:進程

  1. 避免一個線程同時獲取多個鎖
  2. 避免一個鎖內同時佔用多個資源,儘可能保證每個鎖只佔用一個資源
  3. 嘗試使用定時鎖,lock.tryLock(timeout)來替代使用內部鎖機制
  4. 對於數據庫鎖,加索和解鎖必須在一個數據庫連接裏,不然會致使解鎖失敗
八、飢餓

某些線程於其餘線程搶佔CPU時間片時,老是沒有搶佔到CPU時間片,就會使線程處於飢餓狀態內存

九、活鎖

與死鎖相反,活鎖是過分的釋放CPU資源,都不去搶佔資源,致使線程阻塞

相關文章
相關標籤/搜索