1、程序間是獨立的,這表現在記憶體空間,上下文環境,無法突破程序邊界存取其他程序內的儲存空間;
2、執行緒由於處於程序空間內,所以同一程序所產生的執行緒共享同一記憶體空間,同一程序中的兩段程式碼不能夠同時執行,除非引入執行緒,執行緒是屬於程序的,當程序退出時該程序所產生的執行緒都會被強制退出並清除;
3、執行緒佔用的資源要少於程序所佔用的資源,程序和執行緒都可以有優先順序,線上程系統中程序也是一個執行緒,可以將程序理解為一個程式的第一個執行緒。
1、程序間是獨立的,這表現在記憶體空間,上下文環境,無法突破程序邊界存取其他程序內的儲存空間;
2、執行緒由於處於程序空間內,所以同一程序所產生的執行緒共享同一記憶體空間,同一程序中的兩段程式碼不能夠同時執行,除非引入執行緒,執行緒是屬於程序的,當程序退出時該程序所產生的執行緒都會被強制退出並清除;
3、執行緒佔用的資源要少於程序所佔用的資源,程序和執行緒都可以有優先順序,線上程系統中程序也是一個執行緒,可以將程序理解為一個程式的第一個執行緒。
在開銷方面:每個程序都有獨立的程式碼和資料空間(程式上下文),程式之間的切換會有較大的開銷;執行緒可以看做輕量級的程序,同一類執行緒共享程式碼和資料空間,每個執行緒都有自己獨立的執行棧和程式計數器(PC),執行緒之間切換的開銷小。
所處環境:在作業系統中能同時執行多個程序(程式);而在同一個程序(程式)中有多個執行緒同時執行(透過CPU排程,在每個時間片中只有一個執行緒執行)
記憶體分配方面:系統在執行的時候會為每個程序分配不同的記憶體空間;而對執行緒而言,除了CPU外,系統不會為執行緒分配記憶體(執行緒所使用的資源來自其所屬程序的資源),執行緒組之間只能共享資源。
包含關係:沒有執行緒的程序可以看做是單執行緒的,如果一個程序內有多個執行緒,則執行過程不是一條線的,而是多條線(執行緒)共同完成的;執行緒是程序的一部分,所以執行緒也被稱為輕權程序或者輕量級程序。
程序和執行緒的根本區別是程序是作業系統資源分配的基本單位,而執行緒是處理器任務排程和執行的基本單位。另外區別還有資源開銷、包含關係、記憶體分配、影響關係、執行過程等。
資源開銷:每個程序都有獨立的程式碼和資料空間(程式上下文),程式之間的切換會有較大的開銷;執行緒可以看做輕量級的程序,同一類執行緒共享程式碼和資料空間,每個執行緒都有自己獨立的執行棧和程式計數器(PC),執行緒之間切換的開銷小。
包含關係:如果一個程序內有多個執行緒,則執行過程不是一條線的,而是多條線(執行緒)共同完成的;執行緒是程序的一部分,所以執行緒也被稱為輕權程序或者輕量級程序。
記憶體分配:同一程序的執行緒共享本程序的地址空間和資源,而程序之間的地址空間和資源是相互獨立的。
影響關係:一個程序崩潰後,在保護模式下不會對其他程序產生影響,但是一個執行緒崩潰整個程序都死掉。所以多程序要比多執行緒健壯。
執行過程:每個獨立的程序有程式執行的入口、順序執行序列和程式出口。但是執行緒不能獨立執行,必須依存在應用程式中,由應用程式提供多個執行緒執行控制,兩者均可併發執行。
程序和執行緒的根本區別是程序是作業系統資源分配的基本單位,而執行緒是處理器任務排程和執行的基本單位。