1. 程式人生 > >進程和線程的定義、異同、關系

進程和線程的定義、異同、關系

並發執行 組織 順序 pro 自己的 集合 計算 局部變量 等於

一、定義

1.進程

  進程(Process)是程序關於某數據集合上的一次運行(亦稱為執行中的程序),是動態的概念,是系統進行資源分配和調度的獨立單位。在早期面向進程設計的計算機結構中,進程是程序的基本執行實體;在當代面向線程設計的計算機結構中,進程是線程的容器。程序是指令、數據及其組織形式的描述,進程是程序的實體。

2.線程

  線程(Threads),被稱為輕量級進程,是進程中的一個實體,是被系統獨立調度和分派的基本單位,線程自己不擁有系統資源,只擁有一點兒在運行中必不可少的資源(程序計數器,一組寄存器和棧),但它可與同屬一個進程的其它線程共享進程所擁有的全部資源。

二、關系

  一個線程可以創建和撤消另一個線程,同一進程中的多個線程之間可以並發執行。一個程序至少有一個進程,一個進程至少有一個線程。

三、異同

  主要差別在於它們是不同操作系統資源管理方式。進程有獨立的地址空間,一個進程崩潰後,在保護模式下不會對其他進程產生影響,而線程只是一個進程中的不同執行路徑。線程有自己的堆棧和局部變量,但線程之間沒有單獨的地址空間,一個線程死掉就等於整個進程死掉,所以多進程的程序要比多線程的程序健壯,但在進程切換時,耗費資源較大,效率要差一些。但對於一些要求同時進行並且又要共享某些變量的並發操作,只能用線程,不能用進程。

  1. 線程在執行過程中與進程還是有區別的。每個獨立的線程有一個程序運行的入口、順序執行序列和程序的出口。但是線程不能獨立執行,必須依存在進程中,由應用程序提供多個線程執行控制。


  2.從邏輯角度來看,多線程的意義在於一個應用程序中,有多個執行部分同時執行。但操作系統並沒有將多個線程看做多個獨立的應用,來實現進程的調度和管理以及資源分配。這就是進程和線程的重要區別。

  3.進程間資源獨立,同一進程的線程間資源共享。

進程和線程的定義、異同、關系