fork和vfork有什么區(qū)別,作為嵌入式工程師,這個肯定是要掌握的。
不管是fork還是vfork,他們都是為了創(chuàng)建子進程。
函數(shù)原型一樣,沒有參數(shù),但是返回值比較奇怪,別的函數(shù)都是只有一個返回值,但是fork和vfork有兩個。
#include就拿fork來說,程序剛運行的時候,只有一個父進程在運行,執(zhí)行了fork系統(tǒng)調(diào)用后,多了一個子進程,你可以理解成有兩個人在執(zhí)行這段代碼,父進程的fork返回子進程的ID,子進程的fork返回0,所以代碼運行的現(xiàn)象就是fork存在兩個返回值,if語句會進入兩個分支。#include int main() { pid_t pid = fork(); if (-1 == pid) { perror("fork"); exit(-1); } else if (0 == pid) { printf("this is child ... "); } else { printf("this is parent ... "); } return 0; }
fork和vfork的最大區(qū)別就是:fork產(chǎn)生的子進程會復(fù)制父進程的地址空間,在內(nèi)核的進程表中創(chuàng)建一個新的進程表項,新的進程表項有很多屬性和原進程一樣,像堆棧、數(shù)據(jù)段、文件描述符這些都會直接從父進程中繼承過來,而且兩個進程的代碼也一樣。
要說不一樣的地方,比如進程號、父進程號肯定不一樣。
那vfork有什么使用場景,如果fork產(chǎn)生子進程后,子進程立馬調(diào)用exec函數(shù)族啟動了一個新的進程,那么fork產(chǎn)生的地址空間必將浪費。
于是就有了vfork函數(shù),它最大的特點就是父子進程共享同一塊地址空間,這樣也不用給子進程分配資源,因為子進程接下來會被一個全新的進程替換。
除了共享資源上的區(qū)別,還有一些,比如fork產(chǎn)生的子進程和父進程的運行順序不一定,由系統(tǒng)決定,但是vfork產(chǎn)生的子進程一定比父進程先運行。
最后,再來看一下vfork的man手冊。
它提到了有些人認為vfork是一種架構(gòu)缺陷,因為fork有了寫時拷貝機制,所以在有些場景下使用fork再去通過exec啟動新的進程也沒問題。
審核編輯:劉清
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
PID控制
+關(guān)注
關(guān)注
10文章
449瀏覽量
39980 -
printf函數(shù)
+關(guān)注
關(guān)注
0文章
31瀏覽量
5870 -
PID技術(shù)
+關(guān)注
關(guān)注
0文章
4瀏覽量
1961
原文標題:fork和vfork的區(qū)別
文章出處:【微信號:學(xué)益得智能硬件,微信公眾號:學(xué)益得智能硬件】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
Linux下多進程編程之fork()函數(shù)語法
,因此執(zhí)行速度是比較慢的。為了加快fork()的執(zhí)行速度,很多UNIX系統(tǒng)設(shè)計者創(chuàng)建了vfork()。vfork()也能創(chuàng)建新進程,但它不產(chǎn)生父進程的副本。它是通過允許父子進程可訪問相同物理內(nèi)存,從而偽裝
發(fā)表于 08-19 09:28
最常見的fork用法是什么
接口語法用來創(chuàng)造一個子進程在子進程中,成功的fork調(diào)用會返回 0。在父進程中fork返回子進程的 pid。如果出現(xiàn)錯誤,fork返回一個負值成功調(diào)用fork會創(chuàng)建一個新的進程,它幾乎
發(fā)表于 12-15 07:38
hpmicro fork出來的riscv-gnu-toolchain與上游有什么區(qū)別?
找遍官網(wǎng)沒找到先關(guān)信息。有幾個疑問
hpmicro fork出來的riscv-gnu-toolchain 與上游有何區(qū)別?
看到論壇里有文
發(fā)表于 05-26 07:13
Linux系統(tǒng)的fork運行機制分析
如果其中一個進程的輸出結(jié)果是“pid1:1001, pid2:1002”,寫出其他進程的輸出結(jié)果(不考慮進程執(zhí)行順序)。
明顯這道題的目的是考察linux下fork的執(zhí)行機制。下面我們通過分析這個題目,談?wù)凩inux下fork的運行機制。
發(fā)表于 04-26 16:26
?1137次閱讀
Fork/Join框架的軟件重構(gòu)及性能分析
針對目前對于Fork/Join框架應(yīng)用和性能分析的相關(guān)工作還不多的現(xiàn)狀,以JGF基準測試程序套件為基礎(chǔ),對其中的senes、crypt、sparsematmult和sor等程序使用Fork/Join
發(fā)表于 12-29 10:06
?0次下載
如何在GitHub上更新Fork以及PullRequest給源項目
這里有個小技巧:在默認狀態(tài)下,會是Base源項目,Head我自己的Fork項目;這樣選擇任何一個時,會調(diào)到某個無法更新的頁面;解決方法是先Base或Head一個其他人的賬號下的Fork,接著選擇
神奇的vfork
?什么是vfork,網(wǎng)絡(luò)上介紹它的文檔很多,隨便一搜就是一大堆。簡單來說,vfork和fork完成了基本上相同的功能,把進程做了一次復(fù)制,變成兩個進程。在shell中,執(zhí)行命令時,shell程序就是通過“復(fù)制
發(fā)表于 04-02 14:42
?300次閱讀
fork函數(shù)的作用_fork函數(shù)創(chuàng)建進程
在Linux中fork函數(shù)是非常重要的函數(shù),它的作用是從已經(jīng)存在的進程中創(chuàng)建一個子進程,而原進程稱為父進程。
發(fā)表于 12-01 13:41
?7771次閱讀
SystemVerilog中的fork-join_any
fork-join_any和fork-join有所不同,fork-join_any的父進程一直阻塞,直到任何一個并行的子進程結(jié)束。
SystemVerilog中的fork-join
在fork-join語句塊中,每個語句都是并發(fā)進程。在這個語句塊中,父進程一直被阻塞,直到所有由“fork-join”產(chǎn)生的子進程都執(zhí)行完。
SystemVerilog中的fork-join_none
fork-join_none和fork-join、fork-join_any的區(qū)別一樣在于進程退出機制以及對于父進程的影響。
Linux中可怕的fork炸彈介紹
Linux中的Fork炸彈(Fork Bomb)是一種拒絕服務(wù)攻擊的形式,它利用了操作系統(tǒng)中的“fork()”系統(tǒng)調(diào)用。
評論