• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            popen system fork exec等函數的區別

            Posted on 2009-09-28 13:50 Prayer 閱讀(1341) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX

            1、fork()一個程序一調用fork函數,系統就為一個新的進程準備了前述三個段,首先,系統讓新的進程與舊的進程使用同一個代碼段,因為它們的程序還是相同的,對于數據段和堆棧段,系統則復制一份給新的進程,這樣,父進程的所有數據都可以留給子進程,但是,子進程一旦開始運行,雖然它繼承了父進程的一切數據,但實際上數據卻已經分開,相互之間不再有影響了,也就是說,它們之間不再共享任何數據了。而如果兩個進程要共享什么數據的話,就要使用另一套函數(shmget,shmat,shmdt等)來操作。現在,已經是兩個進程了,對于父進程,fork函數返回了子程序的進程號,而對于子程序,fork函數則返回零,這樣,對于程序,只要判斷fork函數的返回值,就知道自己是處于父進程還是子進程中。事實上,目前大多數的unix系統在實現上并沒有作真正的copy。一般的,CPU都是以“頁”為單位分配空間的,象INTEL的CPU,其一頁在通常情況下是4K字節大小,而無論是數據段還是堆棧段都是由許多“頁”構成的,fork函數復制這兩個段,只是“邏輯”上的,并非“物理”上的,也就是說,實際執行fork時,物理空間上兩個進程的數據段和堆棧段都還是共享著的,當有一個進程寫了某個數據時,這時兩個進程之間的數據才有了區別,系統就將有區別的“頁”從物理上也分開。系統在空間上的開銷就可以達到最小。

             2、對于exec系列函數一個進程一旦調用exec類函數,它本身就“死亡”了,系統把代碼段替換成新的程序的代碼,廢棄原有的數據段和堆棧段,并為新程序分配新的數據段與堆棧段,唯一留下的,就是進程號,也就是說,對系統而言,還是同一個進程,不過已經是另一個程序了。不過exec類函數中有的還允許繼承環境變量之類的信息,這個通過exec系列函數中的一部分函數的參數可以得到。

            3.對于popen函數,他會通過command參數重新啟動shell命令,并建立連個進程間的管道通信.

            4.對于system函數,它也會重新啟動shell命令,當執行完畢后,程序會繼續system下一行代碼執行.

            久久精品国产99久久无毒不卡| 久久国产高清一区二区三区| 99精品国产综合久久久久五月天| 久久男人AV资源网站| 久久天天躁狠狠躁夜夜2020| 久久精品视频一| 亚洲国产成人久久精品影视| 亚洲精品高清一二区久久| 久久66热人妻偷产精品9| 久久精品无码一区二区app| 久久久久久精品免费看SSS | 97久久香蕉国产线看观看| 久久国产成人| 久久久国产乱子伦精品作者| 国产成人久久精品麻豆一区| 婷婷综合久久中文字幕蜜桃三电影| 99久久精品无码一区二区毛片 | 久久久久国产| 青青青国产成人久久111网站| 一级做a爰片久久毛片看看| 办公室久久精品| 日本三级久久网| 潮喷大喷水系列无码久久精品| 九九精品久久久久久噜噜| 国产精品激情综合久久| 精品免费tv久久久久久久| 亚洲AV无码久久精品蜜桃| 国产精品久久久久久久app| 久久久久99精品成人片| 久久亚洲国产精品一区二区| 国产婷婷成人久久Av免费高清| 久久人妻AV中文字幕| 久久天天躁狠狠躁夜夜2020一| 2019久久久高清456| 久久99热这里只频精品6| 武侠古典久久婷婷狼人伊人| 欧美一级久久久久久久大| 7777精品伊人久久久大香线蕉| 亚洲国产视频久久| 奇米综合四色77777久久| 99精品国产在热久久无毒不卡 |