JVM-併發-線程

来源:http://www.cnblogs.com/lrh-xl/archive/2016/04/10/5373827.html
-Advertisement-
Play Games

線程 1.線程的實現 (1)實現線程主要有3中方式:使用內核線程實現,使用用戶線程實現和使用用戶線程加輕量級進程混合實現。 (2)使用內核線程實現 內核線程就是直接由操作系統內核支持的線程,這種線程由內核來完成線程切換,內核通過操縱調度器對線程進行調度,並負責將線程映射到處理器上。 局限性:由於是基 ...


 線程

  1.線程的實現

    (1)實現線程主要有3中方式:使用內核線程實現,使用用戶線程實現和使用用戶線程加輕量級進程混合實現。

    (2)使用內核線程實現

      內核線程就是直接由操作系統內核支持的線程,這種線程由內核來完成線程切換,內核通過操縱調度器對線程進行調度,並負責將線程映射到處理器上。

      局限性:由於是基於內核線程實現的,所有線程操作,如創建,析構及同步,都需要進行系統調用。每一個輕量級進程都需要又一個內核線程的支持,因此輕量級進程要消耗一定的資源,因此一個系統支持輕量級進程的數量是有限的。

    (3)使用用戶線程實現

      狹義上的用戶線程指的是完全建立在用戶空間的線程庫上的,系統的內核不能感知線程的存在的實現。用用戶線程的建立、同步、銷毀和調度完全在用戶態中完成,不需要內核的幫助。

    (4)使用用戶線程和輕量級進程混合實現

      混合模式下,既存在用戶進程,也存在輕量級進程。用戶線程還是完全建立在用戶空間中,因此,用戶線程的創建、切換、析構等操作依然廉價,並且可以支持大規模的用戶線程併發。而操作系統提供支持的輕量級進程,則可以作為用戶線程之間的橋梁,這樣可以使用內核提供的線程調度功能及處理器映射,並且用戶線程的系統調用要通過輕量級線程結束完成,大大降低了整個進程被完全阻塞的風險。

    (5)Java線程在JDK1.2之前,是基於稱為“綠色線程”的用戶線程實現的,而在JDK1.2中,線程模型替換為基於操作系統原生線程嗎,模型來實現。

  2.Java線程調度

   (1)線程調度是指系統為線程分配處理器使用權的過程,主要的方式有兩種,分別是協同式線程調度和搶占式線程調度。

   (2)使用協同式調度的多線程系統,線程的執行時間由線程本身來控制,線程把自己的工作執行完成後,要主動通知系統切換到另外一個線程上。

   (3)使用搶占式調度的多線程系統,那麼每個線程將由系統來分配執行時間,線程的切換不由線程本身決定。在這種實現線程調度的方式下,線程的執行時間是系統可控的,也不會有一個線程導致整個進程阻塞的問題,Java使用的線程調度方法就是搶先式調度。

 

  3.轉換
    (1)Java語言定義了5種線程狀態,在任意一個時間點,一個線程只能允許有且只有其中的一種狀態。這5種狀態如下:
      a) 新建(new):創建尚未啟動的線程處於這種狀態
      b) 運行(Runnable):Runnable包括了操作系統線程狀態中的Running和Ready,也就是處於此狀態的線程有可能正在執行,也有可能正在等待著CPU為它分配執行時間。
      c) 無限期等待(Waiting):處於這種狀態的線程不會被分配CPU執行時間,它們要等待被其他線程顯式喚醒。
      d) 限期等待(Timed Waiting):處於這種狀態的線程不會被分配CPU執行時間,不過無須等待被其他線程顯式地喚醒,在一定時間之後它們會由系統自動喚醒。
      e) 阻塞(Blocked):線程狀態被阻塞了,“阻塞狀態”與“等待狀態”的區別是:阻塞狀態在等待著獲取到一個排他鎖,這個事件將一個線程放棄這個鎖的時候發生;而等待狀態則是在等待一段時間,或喚醒動作發生。在程式等待進入同步區域的時候。線程保持這種狀態。
      f) 結束(Terminated):已經終止線程的線程狀態。線程已經結結束執行。

                   

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先是IEnumerable與IEnumerator的定義: 1.IEnumerable介面允許使用foreach迴圈,包含GetEnumerator()方法,可以迭代集合中的項。 2.IEnumerator介面是一個真正的集合訪問器,它包含MoveNext()方法和Current屬性,在forea ...
  • HoverTree解決方案學習C#.NET,Sql Server,WinForm等的解決方案。本文鏈接http://hovertree.com/h/bjaf/0jteg8cv.htm使用的技術、框架、工具包括:.NET Framework 4.5.2Visual Studio 2015Sql Ser ...
  • 對於EF對資料庫的緩存,EF本身也有,但是不能靈活的控制,而且實體對象釋放了緩存就沒有了,總不能使用同一個實體對象(實體對象不支持多線程),基本上就是用完就釋放,而EF的一個擴展框架也提供了緩存操作(源碼:https://github.com/loresoft/EntityFramework.Ext ...
  • KMP演算法是眾多優秀的模式串匹配演算法中較早誕生的一個,也是相對最為人所知的一個。 演算法實現簡單,運行效率高,時間複雜度為O(n+m)(n和m分別為目標串和模式串的長度),比蠻力演算法的O(nm)快了許多。 理解KMP演算法,關鍵是理解其中的精髓——next[]數組。 (統一起見,下文將目標字元串記作ob ...
  • 思想 歸併排序 (merge sort)是建立在歸併操作上的一種有效的排序演算法,它以 O(nlogn) 最壞情形運行時間運行。它是採用分治法(Divide and Conquer)的一個非常典型的應用。將已有序的子序列合併,得到完全有序的序列:即先使每個子序列有序,再使子序列段間有序。若將兩個有序表 ...
  • 顧名思義,可變參數函數就是參數數量可變的函數,即函數的參數數量是不確定的,比如方法getnumbertotal()我們即可以傳遞一個參數,也可以傳遞5個、6個參數 使用可變參數必須註意的是: 必須包含一個普通參數 我們可以給va_start()方法傳遞一個NULL,但是需要通過第一個參數知道可變參數 ...
  • 1、vagrant 為了模擬集群效果,使用vagrant。 1.1、首先下載vagrant https://www.vagrantup.com/downloads.html 說明:瀏覽器下載可能比較慢,可以通過迅雷下載。 1.2、下載之後,安裝vagrant mac中下一步到底就可以。 說明:雖然v ...
  • 在C語言中,函數名也是指針變數,比如創建了一個add(int n,int m)的函數的同時也創建了一個名為add的指針變數,因此我們可以把函數指針當作一種類型為它賦值、當作參數傳遞等操作 C語言創建函數指針的公式: 返回類型 (*指針變數)(參數類型) 雖然函數指針是指針,但是在使用的時候我們可以省 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...