Linux進程與線程的基本概念及區別

来源:https://www.cnblogs.com/Wayne123/archive/2023/03/13/17213052.html
-Advertisement-
Play Games

前言 假設你正在玩一款線上多人游戲,在游戲中,有多個角色需要進行不同的操作,例如攻擊、移動、釋放技能等等。 接下來,我們用玩游戲的例子,來解釋進程和和線程的概念,以及進程和線程的區別。 進程的基本概念 我們可以將整個游戲看作一個進程,它是操作系統中資源分配的基本單位,擁有自己的地址空間、記憶體、CPU ...


前言

假設你正在玩一款線上多人游戲,在游戲中,有多個角色需要進行不同的操作,例如攻擊、移動、釋放技能等等。

接下來,我們用玩游戲的例子,來解釋進程和和線程的概念,以及進程和線程的區別。

進程的基本概念

我們可以將整個游戲看作一個進程,它是操作系統中資源分配的基本單位,擁有自己的地址空間、記憶體、CPU 時間片等資源。

在游戲中,進程相當於整個游戲程式的運行實例,負責接收和處理來自玩家的各種請求,並將結果返回給客戶端。

例如,當你點擊攻擊按鈕時,進程會根據你的請求進行計算,然後將傷害值發送回客戶端,讓你的角色進行攻擊動作。

  • 進程是正在運行中的程式的實例,每個進程都有自己的地址空間、系統資源和狀態。

  • 進程是由操作系統啟動的,它可以包含一個或多個線程。進程的創建是通過系統調用 fork() 函數實現的。

  • 每個進程都具有唯一的 PID,用來唯一標識該進程。

  • PID 是在進程創建時由操作系統分配的,並且在該進程的生命周期中都是唯一的。

  • 進程可通過信號和管道等方式進行通信和同步。

進程創建偽代碼示例:

pid_t pid = fork();
if (pid < 0) {
    // fork 失敗
}
else if (pid == 0) {
    // 子進程邏輯
}
else {
    // 父進程邏輯
}

線程的基本概念

在游戲中,線程可以看作是進程的子任務,它是操作系統中調度的基本單位,但是它與父進程共用地址空間和部分資源,可以並行執行。

在游戲中,每個角色都可以看作是一個線程,它們可以同時進行不同的操作,例如有的角色在攻擊,有的角色在移動。

如果游戲中只有一個線程,那麼所有角色的操作都必須依次執行,這會導致游戲的卡頓和延遲。

  • 線程是進程的執行單位,是在進程內部創建和執行的,可以認為是進程內部的子進程。

  • 線程與進程的不同之處在於它們共用進程的地址空間,包括全局變數、堆棧和代碼段等資源。

  • Linux 中的線程是通過系統調用 pthread_create() 函數創建的,每個線程都有自己獨立的線程 ID 和執行函數。

  • 線程的創建和銷毀是在進程內部完成的,因此線程的開銷要低於進程。

  • 線程的調度由操作系統來完成,調度優先順序、時間片和同步機制是線程的重要屬性。

  • 線程的同步機制可以通過信號量、互斥量和條件變數等實現。

線程偽代碼示例:

pthread_t tid;
int ret = pthread_create(&tid, NULL, start_routine, arg);
if (ret != 0) {
    // 線程創建失敗
}
else {
    // 線程創建成功
}

進程與線程的差異

在游戲中,進程和線程的作用是相互協調,共同完成游戲的各項任務。

進程負責整個游戲的管理和調度,而線程則負責處理每個角色的操作。

當多個角色需要同時執行不同的操作時,線程的並行執行可以提高游戲的運行效率和響應速度。

  • 地址空間:進程具有獨立的地址空間,線程共用進程的地址空間;

  • 資源分配:進程是操作系統中的資源分配的最小單位,而線程則共用同一個進程的資源;

  • 系統開銷:線程創建、撤銷和切換比進程要快,具有較小的開銷;

  • 執行效率:線程之間共用進程的資源,多個線程可以併發執行,程式的效率和響應速度較高

  • 通信方式:進程間的通信和數據交換需要使用特殊的機制(例如管道、共用記憶體等),而線程之間的通信和數據交換則可以直接通過共用的變數和記憶體來實現;

  • 調度方式:進程的調度是由操作系統決定的,而線程的調度則由進程自己控制;

  • 安全性能:進程之間互不影響,安全性較高,而線程之間共用記憶體空間,需要對共用資源進行訪問控制,否則會出現競爭和記憶體泄漏等問題

進程和線程的使用場景

一般來說,當需要進行任務的資源分配和系統調度時,應該選擇使用進程。

如果任務可以並行執行,又需要高效的資源共用和通信,這時候可以使用線程。

選擇進程還是線程的特殊情況:

  1. 系統中存在多個核心和CPU,可以使用多進程或多線程來進行併發執行。

  2. 程式需要使用大量的計算資源,這種情況下多線程執行效率更高。

  3. 程式需要同時處理多個任務,這時候可以使用進程來完成任務的資源分配和系統調度,同時使用線程來執行任務的具體操作。

  4. 對於需要高可靠性的程式(如金融系統等),可以使用多進程來進行處理,從而保證一個進程崩潰不會影響到整個系統的運行。

小結

進程和線程是 Linux 系統中的基本概念,每個進程都擁有獨立的地址空間、系統資源和狀態,而每個線程共用進程的地址空間和資源。在 Linux 中,進程和線程是實現多任務和多線程編程的基礎。通過本文的介紹,您已經瞭解了 Linux 中進程和線程的基本概念及它們之間的區別。

以上,如果覺得對你有幫助,點個贊再走吧,這樣@知微之見也有更新下去的動力!

也歡迎私信我,一起交流!


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

-Advertisement-
Play Games
更多相關文章
  • java 線程池預設提供了幾種拒絕策略: 這幾個策略都實現了RejectedExecutionHandler,拿DiscardOldestPolicy來說,查看源碼: 核心代碼只有2行: e.getQueue().poll() 從列表裡彈出1個(最早的)任務,以便讓隊列空出1個位置 e.execut ...
  • 什麼是Git? Git是一個版本控制系統,用於跟蹤電腦文件的變化。Git是一個跟蹤電腦文件變化的版本控制系統,用於幫助協調一個項目中幾個人的工作,同時跟蹤一段時間的進展。換句話說,我們可以說它是一個促進軟體開發中源代碼管理的工具。 Git和SVN的區別 Git是分散式版本控制系統,SVN是集中式 ...
  • 廣發基金外包面試題 說說Spring AOP 說說stream流的常用API 線程池的參數 MCVV,什麼是普通讀和快照讀 redis分片模式是什麼,redis事務,分片模式下事務會生效嗎 說說rocket mq分散式事務是怎麼做的 為什麼要劃分session,怎麼解決耦合問題 說說是怎麼解決分散式 ...
  • 最近接到一個新的需求,需要上傳2G左右的視頻文件,用測試環境的OSS試了一下,上傳需要十幾分鐘,再考慮到公司的資源問題,果斷放棄該方案。 一提到大文件上傳,我最先想到的就是各種網盤了,現在大家都喜歡將自己收藏的「小電影」上傳到網盤進行保存。網盤一般都支持斷點續傳和文件秒傳功能,減少了網路波動和網路... ...
  • 1. 垃圾回收器 1.1. 對象可以在被需要時創建,不再使用時由JVM自動回收 1.2. GC是查找不再使用的對象,然後回收這些對象相關記憶體的過程 1.2.1. 找到不使用的對象、回收其記憶體、壓縮堆記憶體 1.3. 優化垃圾回收器比跟蹤指針引起的bug要容易得多(且耗時更少) 1.4. VM必須定期搜 ...
  • 簡介 Dapper是介於Entity framework與ADO的折中選擇。既滿足手寫查詢的高性能需求,又簡化了資料庫對象映射為記憶體對象的繁雜工作。Dapper.Contrib是對Dapper的進一步封裝,使對象的基本增刪改查等操作進一步簡化。 為什麼使用Dapper.Contrib 如果僅僅使用D ...
  • 在運行期間,我們可以使用 `Emit` 來組織一段 IL 代碼,進而動態生成一個方法,甚至是一個程式集(包括類型、方法或屬性等等)。這個過程我們稱之為動態編織。這一項技術應用比較廣泛,比如數據映射(Dapper)、動態代理(AOP)等等,目的是提升大量反射而產生的性能問題。 ...
  • Blazor Server,即運行在伺服器上的 Blazor 應用程式,它的優點是應用程式在首次運行時,客戶端不需要下載運行時。但它的代碼是在伺服器上執行的,然後通過 SignalR 通信來更新客戶端的 UI,所以它要求必須建立 Web Socket 連接。 用於 Blazor 應用的 Signal ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...