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í)候,沒必要寫入 主站蜘蛛池模板: 国产小视频国产精品 | 九号影院| 婷婷色影院 | 久久精品国产精品亚洲精品 | 黄色污污视频网站 | 亚洲不卡av不卡一区二区 | 亚洲阿v天堂2021在线观看 | 亚洲欧美婷婷 | 亚洲丁香婷婷综合久久小说 | 欧美日韩亚洲一区二区 | 精品在线一区 | 国产小视频网站 | 亚洲美女自拍偷拍 | 日本一区二区三区视频在线 | 黄色污污视频网站 | 聚会的目的4韩语中文字 | 欧美亚洲视频在线观看 | 久久久久久国产精品免费免费 | 欧美成人午夜做受视频 | 亚洲欧美久久精品一区 | 自拍偷拍亚洲图片 | 最新激情网址 | 成人久久电影 | 久热中文字幕在线精品免费 | 男人天堂官方网站 | 在线你懂得 | 亚洲精品国产77777 | 亚洲美女爱爱 | 亚洲一区二区三区在线免费观看 | 亚洲国产精久久久久久久 | 亚洲精品xxxxx| 国产欧美精品一区aⅴ影院 99精品国产成人一区二区在线 | 国产在线观看不卡 | 四虎4hu永久免费视频大全 | 小视频在线播放 | 中文字幕欧美视频 | 日韩毛片在线视频 | 五月香婷婷 | 性欧美大战久久久久久久野外黑人 | 男人的天堂中文字幕 | 成人午夜性影院视频 |