并发编程——线程——理论知识
一、什么是線程
線程是操作系統能夠進行運算調度的最小單位。
它被包含在進程之中,是進程中的實際運作單位。
一條線程指的是進程中一個單一順序的控制流,一個進程中可以并發多個線程,每條線程并行執行不同的任務
在傳統操作系統中,每個進程有一個地址空間,而且默認就有一個控制線程。
線程顧名思義,就是一條流水線工作的過程(流水線的工作需要電源,電源就相當于cpu),而一條流水線必須屬于一個車間,一個車間的工作過程是一個進程,車間負責把資源整合到一起,是一個資源單位,而一個車間內至少有一條流水線。
所以,進程只是用來把資源集中到一起(進程只是一個資源單位,或者說資源集合),而線程才是cpu上的執行單位。
多線程(即多個控制線程)的概念是,在一個進程中存在多個線程,多個線程共享該進程的地址空間,相當于一個車間內有多條流水線,都共用一個車間的資源。
例如,北京地鐵與上海地鐵是不同的進程,而北京地鐵里的13號線是一個線程,北京地鐵所有的線路共享北京地鐵所有的資源,比如所有的乘客可以被所有線路拉。
二、線程與進程的區別
1.線程共享創建它的進程的地址空間;進程有自己的地址空間。
2.線程可以直接訪問其進程的數據段;進程有自己的父進程的數據段副本。
3.線程可以直接與進程的其他線程通信;進程必須使用進程間通信與同級進程通信。
4.新線程很容易創建;新進程需要復制父進程。
5.線程可以對同一進程的線程進行相當大的控制;進程只能對子進程進行控制。
6.對主線程的更改(取消、優先級更改等)可能會影響進程的其他線程的行為;對父進程的更改不會影響子進程。
三、多線程應用舉例
開啟一個字處理軟件進程,該進程肯定需要辦不止一件事情,比如監聽鍵盤輸入,處理文字,定時自動將文字保存到硬盤,這三個任務操作的都是同一塊數據,因而不能用多進程。
只能在一個進程里并發地開啟三個線程,如果是單線程,那就只能是,鍵盤輸入時,不能處理文字和自動保存,自動保存時又不能輸入和處理文字。
總結
以上是生活随笔為你收集整理的并发编程——线程——理论知识的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 操作系统——理论知识
- 下一篇: 并发编程——线程——线程的理论和创建以及