玩轉C#之【執行序-計算機架構相關名詞】

更新於 發佈於 閱讀時間約 1 分鐘

介紹

計算機架構相關名詞

作業系統相關

  • 電腦程式 (Program)包含一系列指令 (a sequence of instructions) 用來讓電腦運作的檔案
  • 執行 (Execution)將電腦程式中的所有指令載入到記憶體 (RAM) 並建立處理程序的流程
  • 處理程序 (Process)電腦程式實體 (instance of a computer program) (一台電腦可以同時執行多個相同的電腦程式)
    作業系統可能會使用一個多個執行緒來執行電腦程式中的指令 (instructions)
  • 執行緒 (Thread)由作業系統透過排程器(Scheduler)分配執行在電腦程式中一系列指令最小單位
    區分 Kernel threadsUser threads 兩種,負責不同類型的執行任務
  • 排程器 (Scheduling)排程器是作業系統的一個重要元件,用來安排「資源」來執行「工作
    資源包含處理器 (Processor)、核心(Core)、網路、... 等等。
    工作包含執行緒(Thread)、處理程序(Process)、傳輸網路封包 (Traffic flow)、... 等等。
  • 先佔式任務處理 (Preemption)這是一種多工(Multi-Tasking)的實現方式。多工是指電腦同時執行多個程式的能力!
    先佔式任務處理會中斷正在執行中的執行緒,並會在未來的一段時間繼續執行
  • 內容切換 (Context Switching)由於先佔式任務處理會中斷正在執行中的執行緒,在執行緒之間反覆切換的過程叫做內容切換
    Windows / macOS / Linux / AIX / BSD / Solaris 皆採用先佔式多工 (Preemptive Multitasking),一個執行緒執行程式時間用完了,系統就會進行 Context Switch,把 CPU 分配給下一個執行緒,沒有一個程式能獨佔 CPU 時間!
  • 多工處理 (Multi-Tasking)多工是指電腦同時執行多個程式的能力
    多工的一般方法是執行第一個程式的一段代碼,儲存工作環境;再執行第二個程式的一段代碼,儲存環境;……恢復第一個程式的工作環境,執行第一個程式的下一段代碼……現代的多工,每個程式的時間分配相對平均。
  • 多執行緒 (Multithreading)多執行緒是一種利用單一核心來提供多工處理的能力,用來提供同時執行多條執行緒的工作方式,而這種能力通常都是由作業系統內建提供的。
    在多執行緒的應用程式中,執行緒會共用一個或多個核心,而共用的資源包含運算單元、CPU 快取或 TLB (translation lookaside buffer) 等資源。
    新一代的 CPU 基本上都有提供硬體多執行緒的支援,能夠在同一時間執行多於一個執行緒,進而提升整體處理效能
Program vs. Process vs. ThreadScheduling, Preemption, Context Switching
相關名詞
  • 同步 (Synchronous)在計算機的世界裡,沒有什麼程式是真的「同步」的。
    同步通常是指在一個系統中所發生的事件之間進行協調 (coordination of events),讓時間上出現 一致性統一化的現象,讓整件事看起來像是依序執行的結果。
  • 非同步 (Asynchronous)非同步意味著在一個系統中所發生的事件 (occurrence of events) 都可以獨立執行,並且提供一些方法來處理這些事件。
    這些發生的事件不會封鎖(Block)主程式執行緒,因此可以多個工作進行平行處理
  • 同步化 (Synchronization)當多執行緒需要同時存取共用資源時,所需進行的管控機制,確保程式執行時可以得到預期結果
    跨執行緒的同步化: lock, SpinLock, Mutex, ReaderWriterLockSlim, Barrier, CountdownEvent, ...
    跨處理程序同步化:Mutex, Semaphore (Windows), EventWaitHandle (Windows)
    相關文章:Overview of synchronization primitives
  • 執行緒安全 (Thread-safety)在多執行緒環境下執行程式,用以確保執行可以得到預期執行結果
    實現執行緒安全必要條件就是必須能夠提供同步化機制!
  • 同步內容 (SynchronizationContext)允許執行緒透過將工作單元(Work of Unit)進行封裝(Marshal)之後,傳遞給其他執行緒
  • 競爭狀態 (Race Condition)競爭情形是一種錯誤,這種錯誤是指根據兩個或多個執行緒之中,哪一個先到達程式碼的特定區塊而決定程式的結果。
    執行程式多次會產生不同的結果,並且無法預測任何指定的執行結果。
  • 關鍵區段 (Critical Section)是一段程式碼不允許多執行緒同時執行
    為了避免資源競爭的情況發生 (Race Condition)
  • 死結 (Deadlock)當兩個以上執行緒雙方都在等待對方停止執行,以取得系統資源,但是沒有一方會先結束。
    📷

.NET程式啟動流程

  • .NET 處理程序(Process)啟動後,僅會有一個前景執行緒!每個執行程序都可以產生出許多前景執行緒背景執行緒
  • 前景執行緒 (Foreground Thread)所有前景執行緒必須全部結束執行,否則處理程序無法結束執行
    無論是否還有背景執行緒在執行,沒有前景執行緒在跑,該處理程序就一定會結束
    new Thread() 預設就是前景執行緒
  • 背景執行緒 (Background Thread)new Task() 預設就是背景執行緒
    執行緒集區(Thread Pool)取得的執行緒,一定是背景執行緒
    Task.Run
    從執行緒集區取得一個執行緒,因此是背景執行緒
  • 主執行緒(main Thread)程序啟動時的第一個執行緒

參考資料

本篇已同步發表至個人部落格
https://moushih.com/2022ithome18/
我的鐵人賽文章
https://ithelp.ithome.com.tw/articles/10292654
為什麼會看到廣告
avatar-img
8會員
39內容數
我是這個部落格的作者,喜歡分享有關投資 💰、軟體開發 💻、占卜 🔮 和虛擬貨幣 🚀 的知識和經驗。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
一代軍師 的其他內容
Array 在記憶體中連續分配,而且元素類型是一樣的,長度不變 優點:讀取快,可以使用座標訪問 缺點:新增、刪除慢 記憶體: 📷 範例程式碼: ArrayList 不定長度,在記憶體中連續分配的,元素沒有類型限制,任何元素都是當成object處理,如果是值類型,會有裝箱的操作 優點:讀取快 缺點:
介紹 這章節純看智商 不可逆加密:原文加密後變成密文,但密文沒辦法解密文回原文 可逆加密:原文加密過後的密文,可以在將密文解密回原文 對稱:表示加解密是否使用同一個key MD5 不可逆加密 MD5 使用的命名空間是 System.Security.Cryptography MD5是一種公開的算法
環境安裝 這邊可以先安裝Expression Tree Visualizer工具 Viusla studio 2019 安裝方式: 檔案(ExpressionTreeVisualizer.2019)下載完之後,將檔案複製到此目錄: C:\Program Files (x86)\Microsoft V
環境準備 準備用測試資料 語法說明 Where 應用場景:過濾、查詢等功能 說明:與SQL命令中的where功能相似,都是過濾範圍內的數值 例如:使用where篩選,年紀大於30的同學 First 應用場景:篩選出第一筆資料,但資料如果是空的會跳Exception 說明:返回集合中的第一個元素,其實
介紹 LINQ全名是(Language-Integrated Query),是一組以直接將查詢功能整合至C# 語言為基礎之技術的名稱。 大家可以想像SQL有SQL的查詢語法,MySql有MySql的查詢語法,但我們可以只透過LINQ語法,C#會自動幫我們轉換成對應的資料庫查詢語法,有點像是秦始皇統一
介紹 序列化、反序列化概念: 📷 關於泛型委派、解偶、非同步多執行緒、委派的歷史寫法演進之後會專門寫一篇文章跟大家講解 使用方式 測試資料 SerializableAttribute 微軟說明文件 二進位序列化 雖然這裡介紹BinaryFormatter但在 .NET 7中已經屬於過時的方法了
Array 在記憶體中連續分配,而且元素類型是一樣的,長度不變 優點:讀取快,可以使用座標訪問 缺點:新增、刪除慢 記憶體: 📷 範例程式碼: ArrayList 不定長度,在記憶體中連續分配的,元素沒有類型限制,任何元素都是當成object處理,如果是值類型,會有裝箱的操作 優點:讀取快 缺點:
介紹 這章節純看智商 不可逆加密:原文加密後變成密文,但密文沒辦法解密文回原文 可逆加密:原文加密過後的密文,可以在將密文解密回原文 對稱:表示加解密是否使用同一個key MD5 不可逆加密 MD5 使用的命名空間是 System.Security.Cryptography MD5是一種公開的算法
環境安裝 這邊可以先安裝Expression Tree Visualizer工具 Viusla studio 2019 安裝方式: 檔案(ExpressionTreeVisualizer.2019)下載完之後,將檔案複製到此目錄: C:\Program Files (x86)\Microsoft V
環境準備 準備用測試資料 語法說明 Where 應用場景:過濾、查詢等功能 說明:與SQL命令中的where功能相似,都是過濾範圍內的數值 例如:使用where篩選,年紀大於30的同學 First 應用場景:篩選出第一筆資料,但資料如果是空的會跳Exception 說明:返回集合中的第一個元素,其實
介紹 LINQ全名是(Language-Integrated Query),是一組以直接將查詢功能整合至C# 語言為基礎之技術的名稱。 大家可以想像SQL有SQL的查詢語法,MySql有MySql的查詢語法,但我們可以只透過LINQ語法,C#會自動幫我們轉換成對應的資料庫查詢語法,有點像是秦始皇統一
介紹 序列化、反序列化概念: 📷 關於泛型委派、解偶、非同步多執行緒、委派的歷史寫法演進之後會專門寫一篇文章跟大家講解 使用方式 測試資料 SerializableAttribute 微軟說明文件 二進位序列化 雖然這裡介紹BinaryFormatter但在 .NET 7中已經屬於過時的方法了
你可能也想看
Google News 追蹤
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
深入探討操作系統和中央處理單元 (CPU) 的基本概念,涵蓋 OS 的功能、CPU 的運作,以及程式與執行緒的管理。透過生動的比喻,讀者能夠更輕鬆地理解複雜的硬體運作機制,包括記憶體管理和行程間的通訊。本文為想了解計算機科學的讀者提供了一個清晰的入門指南,讓他們掌握多程式協調與虛擬化技術的基本知識。
Thumbnail
本篇文章探討作業系統如何管理程式,介紹了 Process、Thread 及 Process Control Block(PCB)的基本概念。本文以實際例子解釋這些概念,並詳細說明 Context Switch 的運作方式以及程式的五大狀態。
Thumbnail
中央處理器(CPU)是電腦的核心組件,負責執行程式指令及數據處理。本文介紹了CPU的主要功能及結構,包括算數邏輯單元(ALU)和控制單元(CU)等元件,並說明其性能影響因素及工作原理,幫助讀者理解CPU如何影響電腦的速度和效率。
Thumbnail
指令集是電腦處理器(CPU)執行計算和控制系統的核心指令集合。本文介紹了指令集的重要性,以及複雜指令集和精簡指令集的主要特徵和差異。CISC允許單一指令執行多個操作,適合早期軟體設計,而RISC則強調指令的簡化和流水線處理,適用於現代處理器架構。透過這些比較,本文為理解當今計算機架構奠定了基礎。
“所有人寫的程式會變成指令 每一道指令是由CPU執行 而CPU所能理解的指令類型有限”
Thumbnail
電腦的運作需要仰賴許多的硬體與軟體,統稱電腦系統 (computer system)。這篇文章會概略地介紹電腦系統中的重要角色,以及它們如何相互合作,來完成複雜的工作,比如說讓無所事事的宅宅如我,假日可以躲在房間玩一整天的遊戲。 電腦、程式、與使用者 說到電腦,你的腦中會浮現什麼呢? 是螢幕
Thumbnail
電腦只做一件事情: 運算。 我們所看到的任何酷酷的應用: 不論是網頁動畫、遊戲特效、甚至是 AI 說的話,全部都 是由電腦的運算結果組合而成的。 首先我們來梳理一下各個名詞之間的關聯: 1. 運算分成兩個部分: 運算子 (運算的名稱,如: 加法) 和運算元 (運算的對象,如: 8)。運算就是對資
Thumbnail
筆記-2024.03.16-曲博 財訊訪談-談ARM *處理器的兩種架構: 精簡指令集RISC 複雜指令集CISC, *CPU為複雜指令集,運算能力較強,缺點是較耗電。 *ARM,為精簡指令集,運算效能較差,但較省電,屬於微處理器(MPU)。 *英特爾稱霸電腦用CPU, 然而手機較看重
計算機組織不難,但東西很多 這個科目也是我比較不熟悉的,在此之前都是自學,所以會寫的更詳細一點 1.計算機組織在學什麼? 想像計算機的架構就像一個蛋糕有好多層,上半是軟體下半則是硬體,對我來說,軟硬體的兩端是電腦的核心(應用程式&半導體),而中間的每一層都是串接兩端的橋樑;那計算機組織就是要探
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
深入探討操作系統和中央處理單元 (CPU) 的基本概念,涵蓋 OS 的功能、CPU 的運作,以及程式與執行緒的管理。透過生動的比喻,讀者能夠更輕鬆地理解複雜的硬體運作機制,包括記憶體管理和行程間的通訊。本文為想了解計算機科學的讀者提供了一個清晰的入門指南,讓他們掌握多程式協調與虛擬化技術的基本知識。
Thumbnail
本篇文章探討作業系統如何管理程式,介紹了 Process、Thread 及 Process Control Block(PCB)的基本概念。本文以實際例子解釋這些概念,並詳細說明 Context Switch 的運作方式以及程式的五大狀態。
Thumbnail
中央處理器(CPU)是電腦的核心組件,負責執行程式指令及數據處理。本文介紹了CPU的主要功能及結構,包括算數邏輯單元(ALU)和控制單元(CU)等元件,並說明其性能影響因素及工作原理,幫助讀者理解CPU如何影響電腦的速度和效率。
Thumbnail
指令集是電腦處理器(CPU)執行計算和控制系統的核心指令集合。本文介紹了指令集的重要性,以及複雜指令集和精簡指令集的主要特徵和差異。CISC允許單一指令執行多個操作,適合早期軟體設計,而RISC則強調指令的簡化和流水線處理,適用於現代處理器架構。透過這些比較,本文為理解當今計算機架構奠定了基礎。
“所有人寫的程式會變成指令 每一道指令是由CPU執行 而CPU所能理解的指令類型有限”
Thumbnail
電腦的運作需要仰賴許多的硬體與軟體,統稱電腦系統 (computer system)。這篇文章會概略地介紹電腦系統中的重要角色,以及它們如何相互合作,來完成複雜的工作,比如說讓無所事事的宅宅如我,假日可以躲在房間玩一整天的遊戲。 電腦、程式、與使用者 說到電腦,你的腦中會浮現什麼呢? 是螢幕
Thumbnail
電腦只做一件事情: 運算。 我們所看到的任何酷酷的應用: 不論是網頁動畫、遊戲特效、甚至是 AI 說的話,全部都 是由電腦的運算結果組合而成的。 首先我們來梳理一下各個名詞之間的關聯: 1. 運算分成兩個部分: 運算子 (運算的名稱,如: 加法) 和運算元 (運算的對象,如: 8)。運算就是對資
Thumbnail
筆記-2024.03.16-曲博 財訊訪談-談ARM *處理器的兩種架構: 精簡指令集RISC 複雜指令集CISC, *CPU為複雜指令集,運算能力較強,缺點是較耗電。 *ARM,為精簡指令集,運算效能較差,但較省電,屬於微處理器(MPU)。 *英特爾稱霸電腦用CPU, 然而手機較看重
計算機組織不難,但東西很多 這個科目也是我比較不熟悉的,在此之前都是自學,所以會寫的更詳細一點 1.計算機組織在學什麼? 想像計算機的架構就像一個蛋糕有好多層,上半是軟體下半則是硬體,對我來說,軟硬體的兩端是電腦的核心(應用程式&半導體),而中間的每一層都是串接兩端的橋樑;那計算機組織就是要探