01.進(jìn)程通信
進(jìn)程之間需要某種協(xié)同,所以如何協(xié)同的前提條件就是進(jìn)程直接需要進(jìn)行通信,傳遞有效數(shù)據(jù)
前面提到過(guò),進(jìn)程是具有獨(dú)立性的,進(jìn)程=內(nèi)核數(shù)據(jù)結(jié)構(gòu)+代碼和數(shù)據(jù)
前面講到子進(jìn)程創(chuàng)建會(huì)繼承父進(jìn)程的信息,后面會(huì)發(fā)生寫時(shí)拷貝,不屬于進(jìn)程間通信,我們提到的進(jìn)程間通信,是讓其一直通信
進(jìn)程如何通信呢?
因?yàn)檫M(jìn)程具有獨(dú)立性,所以一個(gè)進(jìn)程開辟的資源另一個(gè)進(jìn)程是看不到的,所以進(jìn)程間通信的前提,先讓不同的進(jìn)程,看到同一份(操作系統(tǒng))資源(“一段內(nèi)存”)

一定是某一個(gè)進(jìn)程先需要通信,讓OS創(chuàng)建一個(gè)共享資源
OS必須提供很多系統(tǒng)調(diào)用
OS創(chuàng)建的共享資源的不同,系統(tǒng)調(diào)用接口的不同,進(jìn)程間通信會(huì)有不同的種類
進(jìn)程通信的常見方式:
System V IPC:System V 消息隊(duì)列,System V 共享內(nèi)存,System V 信號(hào)量
POSIX IPC:消息隊(duì)列,共享內(nèi)存,信號(hào)量,互斥量,條件變量,讀寫鎖
管道:匿名管道pipe,命名管道
02.管道

操作系統(tǒng)打開一個(gè)文件,屬性初始化struct file,內(nèi)容寫到內(nèi)核級(jí)文件緩沖區(qū)
當(dāng)以讀和寫兩種方式分別打開同一個(gè)文件時(shí),操作系統(tǒng)為其分配文件描述符fd 3 4 ,當(dāng)?shù)诙未蜷_同一個(gè)文件的時(shí)候,操作系統(tǒng)不需要再將文件的屬性,操作方法集,緩沖區(qū)再加載一次,只有struct file會(huì)被單獨(dú)創(chuàng)建兩次
創(chuàng)建子進(jìn)程以父進(jìn)程模版copy一份,子進(jìn)程文件描述符表也創(chuàng)建一份

創(chuàng)建子進(jìn)程,還需要為3,4描述符再拷貝兩個(gè)Struct file嗎?答案是不用的,進(jìn)程的獨(dú)立性跟文件沒有關(guān)系
這里的拷貝類似淺拷貝的過(guò)程,子進(jìn)程的3,4號(hào)指針也會(huì)指向文件系統(tǒng)中父進(jìn)程指向的同一個(gè)struct file
所以為什么父子進(jìn)程會(huì)向同一個(gè)顯示器終端打印數(shù)據(jù)?就是因?yàn)槲募枋龇赶蛲粋€(gè)文件
進(jìn)程默認(rèn)會(huì)打開三個(gè)標(biāo)準(zhǔn)輸入輸出:0,1,2,怎么做到的?bash的子進(jìn)程–bash打開了,所有的子進(jìn)程默認(rèn)也就打開了,我們只要做好約定即可
我們子進(jìn)程主動(dòng)close(0/1/2),不影響父進(jìn)程繼續(xù)使用顯示器文件
前面也提到,文件會(huì)記錄自己的硬鏈接數(shù),這里struct file也會(huì)記錄指向自己的文件描述符個(gè)數(shù),當(dāng)ref_count等于0時(shí)釋放文件資源
進(jìn)程間通信的本質(zhì),先讓兩個(gè)不同的進(jìn)程看到一份公共的資源,這里父子進(jìn)程看到了同一塊文件內(nèi)核級(jí)緩沖區(qū),這里的公共資源,我們就將它叫做管道文件
管道只允許單向通信,不需要刷新到磁盤,所以需要重新設(shè)計(jì)通信接口

#include
代碼語(yǔ)言:JavaScript代碼運(yùn)行次數(shù):0運(yùn)行復(fù)制
int pipe(int fd[2]);
參數(shù) fd:文件描述符數(shù)組,其中fd[0]表示讀端, fd[1]表示寫端 返回值:成功返回0,失敗返回錯(cuò)誤代碼
本質(zhì)是對(duì)open的封裝,不需要文件路徑和文件名,所以叫做匿名管道


如果想雙向通信,就構(gòu)建兩個(gè)管道
測(cè)試管道接口代碼語(yǔ)言:javascript代碼運(yùn)行次數(shù):0運(yùn)行復(fù)制
#include<iostream>#include<string>#include<cerrno>#include<unistd.h>#include<sys>#include<cstring>#include<sys>using namespace std;string getOtherMessage(){ static int cnt=0; string messageid=to_string(cnt); cnt++; pid_t self_id =getpid(); string stringpid =to_string(self_id); string message = "messageid: "; message+=messageid; message+="my pid is: "; message+=stringpid+"n"; return message;}void SubProcessWrite(int wfd){ string message="I am chile process"; while(true) { string info=message+ getOtherMessage(); write(wfd,info.c_str(),info.size());//寫入管道的時(shí)候,沒必要寫入 主站蜘蛛池模板: 黄色一级片免费网站 | 国产羞羞视频 | 欧美一区二区日韩一区二区 | 亚洲男人天堂a | 亚洲男性天堂 | 欧美亚洲自拍偷拍 | 日韩精品视频免费网址 | 羞羞色院91精品网站 | 五月激情综合网 | 激情五月深爱五月 | 在线观看免费精品国产 | 亚洲精品美女久久久aaa | 5月丁香6月婷婷 | 久久久久国产免费 | 激情综合激情 | 欧美福利视频 | 日日综合 | 羞羞的视频免费观看 | 亚洲视频二 | 日本在线免费播放 | 国产精品一级毛片不收费 | 欧美精品专区免费观看 | 在线精品国内外视频 | 99在线视频网站 | 亚洲成人免费看 | 亚洲福利视频 | 麻豆专媒体公司网站 | 九九视频免费观看 | 亚洲国产精品看片在线观看 | 婷婷六月丁香午夜爱爱 | 国产综合精品久久久久成人影 | 中文字幕在线观看亚洲 | 男女视频网站 | 亚洲精品午夜国产va久久成人 | 亚洲欧美亚洲 | 国产玖玖| 亚洲图片在线播放 | 国产高清在线观看视频手机版 | 男女激情视频网站 | 亚洲精品另类 | 亚洲精品自拍区在线观看 |