當前位置:編程學習大全網 - 編程語言 - 什麽是多線程和多進程

什麽是多線程和多進程

線程和進程都是現在電腦概念裏比較時髦的用語,什麽是多線程,什麽是多進程?本文詳細的給您介紹壹下,希望能增進您對當代電腦技術的了解,有不到之處,還往高手予以更正。進程(英語:Process,中國大陸譯作進程,臺灣譯作行程)是計算機中已運行程序的實體。進程本身不會運行,是線程的容器。程序本身只是指令的集合,進程才是程序(那些指令)的真正運行。若幹進程有可能與同壹個程序相關系,且每個進程皆可以同步(循序)或不同步(平行)的方式獨立運行。進程為現今分時系統的基本運作單位 線程(英語:thread,臺灣譯為運行緒),操作系統技術中的術語,是操作系統能夠進行運算調度的最小單位。它被包涵在進程之中,壹條線程指的是進程中壹個單壹順序的控制流,壹個進程中可以並發多個線程,每條線程並行執行不同的任務。在Unix System V及SunOS中也被稱為輕量進程(lightweight processes),但輕量進程更多指內核線程(kernel thread),而把用戶線程(user thread)稱為線程。 線程是獨立調度和分派的基本單位。線程可以操作系統內核調度的內核線程,如Win32 線程;由用戶進程自行調度的用戶線程,如Linux Portable Thread; 或者由內核與用戶進程,如Windows 7的線程,進行混合調度。 同壹進程中的多條線程將***享該進程中的全部系統資源,如虛擬地址空間,文件描述符和信號處理等等。但同壹進程中的多個線程有各自的調用棧(call stack),自己的寄存器環境(register context),自己的線程本地存儲(thread-local storage)。 壹個進程可以有很多線程,每條線程並行執行不同的任務。 在多核或多CPU,或支持Hyper-threading的CPU上使用多線程程序設計的好處是顯而易見,即提高了程序的執行吞吐率。在單CPU單核的計算機上,使用多線程技術,也可以把進程中負責IO處理、人機交互而常備阻塞的部分與密集計算的部分分開來執行,編寫專門的workhorse線程執行密集計算,從而提高了程序的執行效率 進程是資源分配的最小單位,線程是CPU調度的最小單位。線程和進程的區別在於,子進程和父進程有不同的代碼和數據空間,而多個線程則***享數據空間,每個線程有自己的執行堆棧和程序計數器為其執行上下文.多線程主要是為了節約CPU時間,發揮利用,根據具體情況而定. 線程的運行中需要使用計算機的內存資源和CPU。 多進程: 進程是程序在計算機上的壹次執行活動。當妳運行壹個程序,妳就啟動了壹個進程。顯然,程序是死的(靜態的),進程是活的(動態的)。進程可以分為系統進程和用戶進程。凡是用於完成操作系統的各種功能的進程就是系統進程,它們就是處於運行狀態下的操作系統本身;所有由用戶啟動的進程都是用戶進程。進程是操作系統進行資源分配的單位。 進程又被細化為線程,也就是壹個進程下有多個能獨立運行的更小的單位。在同壹個時間裏,同壹個計算機系統中如果允許兩個或兩個以上的進程處於運行狀態,這便是多任務。現代的操作系統幾乎都是多任務操作系統,能夠同時管理多個進程的運行。 多任務帶來的好處是明顯的,比如妳可以邊聽mp3邊上網,與此同時甚至可以將下載的文檔打印出來,而這些任務之間絲毫不會相互幹擾。那麽這裏就涉及到並行的問題,俗話說,壹心不能二用,這對計算機也壹樣,原則上壹個CPU只能分配給壹個進程,以便運行這個進程。我們通常使用的計算機中只有壹個CPU,也就是說只有壹顆心,要讓它壹心多用,同時運行多個進程,就必須使用並發技術。實現並發技術相當復雜,最容易理解的是“時間片輪轉進程調度算法”,它的思想簡單介紹如下:在操作系統的管理下,所有正在運行的進程輪流使用CPU,每個進程允許占用CPU的時間非常短(比如10毫秒),這樣用戶根本感覺不出來 CPU是在輪流為多個進程服務,就好象所有的進程都在不間斷地運行壹樣。但實際上在任何壹個時間內有且僅有壹個進程占有CPU。 如果壹臺計算機有多個CPU,情況就不同了,如果進程數小於CPU數,則不同的進程可以分配給不同的CPU來運行,這樣,多個進程就是真正同時運行的,這便是並行。但如果進程數大於CPU數,則仍然需要使用並發技術。 進行CPU分配是以線程為單位的,壹個進程可能由多個線程組成,這時情況更加復雜,但簡單地說,有如下關系: 總線程數 CPU數量:並發運行 並行運行的效率顯然高於並發運行,所以在多CPU的計算機中,多任務的效率比較高。但是,如果在多CPU計算機中只運行壹個進程(線程),就不能發揮多CPU的優勢。 這裏涉及到多任務操作系統的問題,多任務操作系統(如Windows)的基本原理是:操作系統將CPU的時間片分配給多個線程,每個線程在操作系統指定的時間片內完成(註意,這裏的多個線程是分屬於不同進程的).操作系統不斷的從壹個線程的執行切換到另壹個線程的執行,如此往復,宏觀上看來,就好像是多個線程在壹起執行.由於這多個線程分屬於不同的進程,因此在我們看來,就好像是多個進程在同時執行,這樣就實現了多任務 多線程:在計算機編程中,壹個基本的概念就是同時對多個任務加以控制。許多程序設計問題都要求程序能夠停下手頭的工作,改為處理其他壹些問題,再返回主進程。可以通過多種途徑達到這個目的。最開始的時候,那些掌握機器低級語言的程序員編寫壹些“中斷服務例程”,主進程的暫停是通過硬件級的中斷實現的。盡管這是壹種有用的方法,但編出的程序很難移植,由此造成了另壹類的代價高昂問題。中斷對那些實時性很強的任務來說是很有必要的。但對於其他許多問題,只要求將問題劃分進入獨立運行的程序片斷中,使整個程序能更迅速地響應用戶的請求。 最開始,線程只是用於分配單個處理器的處理時間的壹種工具。但假如操作系統本身支持多個處理器,那麽每個線程都可分配給壹個不同的處理器,真正進入“並行運算”狀態。從程序設計語言的角度看,多線程操作最有價值的特性之壹就是程序員不必關心到底使用了多少個處理器。程序在邏輯意義上被分割為數個線程;假如機器本身安裝了多個處理器,那麽程序會運行得更快,毋需作出任何特殊的調校。根據前面的論述,大家可能感覺線程處理非常簡單。但必須註意壹個問題:***享資源!如果有多個線程同時運行,而且它們試圖訪問相同的資源,就會遇到壹個問題。舉個例子來說,兩個線程不能將信息同時發送給壹臺打印機。為解決這個問題,對那些可***享的資源來說(比如打印機),它們在使用期間必須進入鎖定狀態。所以壹個線程可將資源鎖定,在完成了它的任務後,再解開(釋放)這個鎖,使其他線程可以接著使用同樣的資源。 多線程是為了同步完成多項任務,不是為了提高運行效率,而是為了提高資源使用效率來提高系統的效率。線程是在同壹時間需要完成多項任務的時候實現的。 壹個采用了多線程技術的應用程序可以更好地利用系統資源。其主要優勢在於充分利用了CPU的空閑時間片,可以用盡可能少的時間來對用戶的要求做出響應,使得進程的整體運行效率得到較大提高,同時增強了應用程序的靈活性。更為重要的是,由於同壹進程的所有線程是***享同壹內存,所以不需要特殊的數據傳送機制,不需要建立***享存儲區或***享文件,從而使得不同任務之間的協調操作與運行、數據的交互、資源的分配等問題更加易於解決。進程間通信(IPC,Inter-Process Communication),指至少兩個進程或線程間傳送數據或信號的壹些技術或方法。進程是計算機系統分配資源的最小單位。每個進程都有自己的壹部分獨立的系統資源,彼此是隔離的。為了能使不同的進程互相訪問資源並進行協調工作,才有了進程間通信。這些進程可以運行在同壹計算機上或網絡連接的不同計算機上。 進程間通信技術包括消息傳遞、同步、***享內存和遠程過程調用。

  • 上一篇:記事本編程bat文件是哪種編程
  • 下一篇:怎樣封鎖隨身WIFI禁止無線網卡
  • copyright 2024編程學習大全網