溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

IPC-管道通信

發(fā)布時間:2020-07-08 17:55:45 來源:網(wǎng)絡 閱讀:495 作者:LHSTS 欄目:編程語言

管道(PIPE)


管道是一種最基本的IPC機制,由pipe函數(shù)在內(nèi)核中開辟一塊緩沖區(qū)(稱為管道)用于通信,所以管道在用戶程序看起來就像一個打開的文件,通過read(filedes[0]);或者write(filedes[1]);

int pipe(int filedes[2]);

參數(shù):filedes參數(shù)傳給用戶程序兩個文件描述符表。filedes[0]指向管道的讀端,filedes[1]指向管道的
寫端

返回值:成功返回0,失敗返回-1

int fseek(FILE *stream, long offset, int fromwhere);

stream:將指向以fromwhere為基準

offset:偏移offset(指針偏移量)個字節(jié)的位置

返回值

    失敗:(比如offset超過文件自身大小),則不改變stream指向的位置,函數(shù)返回一個非0值。

    成功:stream將指向fromwhere,偏移量offset個字節(jié)的位置。

父子進程通信的步驟:

1.父進程創(chuàng)建管道,開辟管道,得到兩個文件描述符指向管道的兩端IPC-管道通信
2.父進程fork創(chuàng)建出子進程,那么子進程也有兩個文件描述符指向同一管道IPC-管道通信
3.父進程關(guān)閉fd[0],子進程關(guān)閉fd[1]。父進程可以往管道里寫,子進程可以往管道里讀,管道是環(huán)形隊列實現(xiàn)的,數(shù)據(jù)從寫端流入,讀端流出,這就實現(xiàn)了進程間通信。IPC-管道通信

管道內(nèi)部的實現(xiàn)機制:

IPC-管道通信

實際上管道沒有單獨的實現(xiàn)數(shù)據(jù)結(jié)構(gòu) ,他利用文件在Linux中,而是借助文件系統(tǒng)的file結(jié)構(gòu)和VFS文件索引節(jié)點inode,通過將兩個 file 結(jié)構(gòu)指向同一個臨時的VFS 索引節(jié)點,而這個 VFS 索引節(jié)點又指向一個物理頁面而實現(xiàn)的。有兩個file數(shù)據(jù)結(jié)構(gòu),但它們定義文件操作例程地址是不同的,其中一個是向管道中寫入數(shù)據(jù)的例程地址,而另一個是從管道中讀出數(shù)據(jù)的例程地址。這樣,用戶程序的系統(tǒng)調(diào)用仍然是通常的文件操作,而內(nèi)核卻利用這種抽象機制實現(xiàn)了管道這一特殊操作。

測試管道容量

測試原理:讀端不讀,寫端一直寫

#include<unistd.h>
#include<stdio.h>
#include<stdlib.h>
#include<error.h>
#include<string.h>
#include<sys/wait.h>

int get_pipe_size(FILE* fd)
{
    fseek(fd,0,SEEK_SET);
    int start = ftell(fd);
    fseek(fd,0,SEEK_END);
    int end = ftell(fd);
    return end - start;
}

int main()
{
    int _pipe[2];
    int ret = pipe(_pipe);
    if(ret == -1)
    {
    //    printf("create pipe error ,error code is:%d\n",error);
        return 1;
    }

    pid_t id = fork();
    if(id <0)
    {
        printf("fork error");
        return 2;
    }
    else if(id == 0)  //child 關(guān)閉讀端
    {
        close(_pipe[0]);
        int i =0;
        char* _msg = NULL;

        //the writer keep writing
        while(1)
        {
            _msg = "r";
            write(_pipe[1],_msg,strlen(_msg));  //一直寫
            printf("%d\n",i);
            i++;
        }
        printf("write over...\n");
    }

    else
    {
        //father
        close(_pipe[1]);//關(guān)閉寫端
        char _msg[100];
        int j =0;
        sleep(5);
        int status = 0;
        while(1)
        {
            status = 0;
            memset(_msg,'\0',sizeof(_msg));
            printf("%s:code id:%d\n",_msg,ret);

        }
        if(waitpid(id,&status,0)<0)
        {
            return 3;
        }
        printf("status:%d\n",(status)&0xff);
    }
    return 0;
}

測試結(jié)果:大約64k

IPC-管道通信



向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI