swoole進程與線程有什么區別

區別:1、進程是系統中正在運行的一個程序,而線程是屬于進程的,一個進程可以擁有多個線程,線程是程序中的執行者;2、進程之間不會共享任何的狀態,而線程之間可以共享變量。

swoole進程與線程有什么區別

本教程操作環境:Windows10系統、swoole4版、DELL G3電腦

swoole進程與線程有什么區別

進程

1、進程之間不共享任何狀態

2、進程的調度由操作系統完成

3、每個進程都有自己獨立的內存空間

4、進程間通訊主要是通過信號傳遞的方式來實現的,實現方式有多種,信號量、管道、事件等,任何一種方式的通訊效率都需要過內核,導致通訊效率比較低

5、由于是獨立的內存空間,上下文切換的時候需要保存先調用的信息、cpu各寄存器的信息、虛擬內存、以及打開的相關句柄等信息,所以導致上下文進程間切換開銷很大,通訊麻煩。

線程

1、線程之間共享變量,解決了通訊麻煩的問題對于變量的訪問需要鎖

2、一個進程可以擁有多個線程,但是其中每個線程會共享父進程像操作系統申請資源,這個包括虛擬內存、文件等,由于是共享資源,所以創建線程所需要的系統資源占用比進程小很多,相應的可創建的線程數量也變得相對多很多。

3、另外在調度方面也是由于內存是共享的,所以上下文切換的時候需要保存的東西就像對少一些,這樣一來上下文的切換也變得高效。

什么是進程?

進程是系統中正在運行的一個程序,程序一旦運行就是進程。

進程可以看成程序執行的一個實例。

Tags:一個進程無法訪問另一個進程的變量和數據結構,如果想讓一個進程訪問另一個進程的資源,需要使用進程間通信,比如管道,文件,套接字等。

什么是線程?

線程屬于進程,是程序的執行者。

一個進程至少包含一個主線程,也可以有更多的子線程,每個線程使用其所屬進程的棧空間。

線程是進程的一個實體,是進程的一條執行路徑。

Tags:同一進程內的多個線程會共享部分狀態,多個線程可以讀寫同一塊內存。

推薦學習: swoole教程

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊15 分享