進程間的通信IPC(無名管道和命名管道)

在這里插入圖片描述進程間的通信IPC介紹
進程間通信(IPC,InterProcess Communication)是指在不同進程之間傳播或交換信息。

IPC的方式通常有管道(包括無名管道和命名管道)、消息隊列、信號量、共享存儲、Socket、Streams等。其中 Socket和Streams支持不同主機上的兩個進程IPC。
一、管道
管道,通常指無名管道,是 UNIX 系統IPC最古老的形式。
(1)特點:

它是半雙工的(即數據只能在一個方向上流動),具有固定的讀端和寫端。它只能用于具有親緣關系的進程之間的通信(也是父子進程或者兄弟進程之間)。它可以看成是一種特殊的文件,對于它的讀寫也可以使用普通的read、write 等函數。但是它不是普通的文件,并不屬于其他任何文件系統,并且只存在于內存中。

(2)原型:

#include <unistd.h>
int pipe(int pipefd[2]);
// 返回值:若成功返回0,失敗返回-1

當一個管道建立時,它會創建兩個文件描述符:fd[0]為讀而打開,fd[1]為寫而打開。要關閉管道只需將這兩個文件描述符關閉即可。

#include<stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
int main()
{//int pipe(int pipefd[2]);int fd[2];//兩個文件描述符pid_t pid;char *readbuf=NULL;readbuf=(char*)malloc(128);if(pipe(fd)==-1){//創建管道printf("creat pipe fail\n");}pid=fork();if(pid<0){printf("creat child fail\n");}else if(pid>0){sleep(3);printf("this is father\n");close(fd[0]);write(fd[1],"hello from father",strlen("hello from father"));wait(NULL);}else{printf("this is child\n");close(fd[1]);read(fd[0],readbuf,128);printf("read from father is %s\n",readbuf);exit(-1);
}

二、FIFO
FIFO,也稱為命名管道,它是一種文件類型。

特點:

FIFO可以在無關的進程之間交換數據,與無名管道不同。FIFO有路徑名與之相關聯,它以一種特殊設備文件形式存在于文件系統中。

原型:

#include <sys/stat.h>
// 返回值:成功返回0,出錯返回-1
int mkfifo(const char *pathname, mode_t mode);

其中的 mode 參數與open函數中的 mode 相同。一旦創建了一個 FIFO,就可以用一般的文件I/O函數操作它。pathname是文件名(管道名)。

當 open 一個FIFO時,是否設置非阻塞標志(O_NONBLOCK)的區別:

若沒有指定O_NONBLOCK(默認),只讀 open 要阻塞到某個其他進程為寫而打開此 FIFO。類似的,只寫 open 要阻塞到某個其他進程為讀而打開它。若指定了O_NONBLOCK,則只讀 open 立即返回。而只寫 open 將出錯返回 -1 如果沒有進程已經為讀而打開該 FIFO,其errno置ENXIO。

寫端代碼

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include<errno.h>
#include <fcntl.h>
#include<string.h>
int main()
{//int mkfifo(char*pathname,mode_t mode);int fd;int cnt=0;char*str="message from file";fd=open("./file",O_WRONLY);while(1){write(fd,str,strlen(str));sleep(1);if(cnt==5){break;}}close(fd);printf("write open successful\n");return 0;
}

讀端代碼

#include<stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include<errno.h>
#include <fcntl.h>
int main()
{//int mkfifo(char*pathname,mode_t mode);int fd;int nread=0;char buf[30]={0};if(mkfifo("./file",0600)==-1&& errno!=EEXIST){printf("mkfifo fail\n");perror("why");}fd=open("./file",O_RDONLY);//fd=open("./file",O_RDONLY|O_NONBLOCK);非堵塞方式打開printf("open successful\n");while(1){nread=read(fd,buf,20);//若沒有寫端將會堵塞在這里printf("read %d byte from file,context is%s\n",nread,buf);}close(fd);return 0;
}

詳細介紹

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/272492.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/272492.shtml
英文地址,請注明出處:http://en.pswp.cn/news/272492.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

那些關于瀏覽器的趣圖和幽默段子

1、當瀏覽器化作一種槍&#xff0c;你喜歡用哪種呢&#xff1f;2、這神奇的反射弧&#xff0c;有點長…3、瀏覽器們成長的煩惱4、這么說來&#xff0c;IE瀏覽器扳回一分&#xff01;5、如何用瀏覽器區分 HTML和 HTML56、都在吹牛&#xff0c;還是IE最務實&#xff01;7、主流瀏…

前端新手程序員不知道的 20個小技巧

1.作為前端開發者&#xff0c;使用雙顯示器能大幅提高開發效率。2.學編程最好的語言不是PHP&#xff0c;是English。3.東西交付之前偷偷測試一遍。4.問別人之前最好先自己百度&#xff0c;google一下&#xff0c;以免問出太低級的問題。5.把覺得不靠譜的需求放到最后做&#xf…

IPC 共享內存和 消息隊列(發送、接收、移除)以及鍵值的生成

一、消息對列 消息隊列&#xff0c;是消息的鏈接表&#xff0c;存放在內核中。一個消息隊列由一個標識符&#xff08;即隊列ID&#xff09;來標識。 特點&#xff1a; 消息隊列是面向記錄的&#xff0c;其中的消息具有特定的格式以及特定的優先級。消息隊列獨立于發送與接收進…

DBA十大必備工具(SQLServer)

曾經和一些DBA和數據庫開發人員交流時&#xff0c;問他們都用過一些什么樣的DB方面的工具&#xff0c;大部分人除了SSMS和Profile之外&#xff0c;基本就沒有使用過其他工具了&#xff1b;誠然&#xff0c;SSMS和Profile足夠強大&#xff0c;工作的大部分內容都能通過它們搞定&…

linux 信號和信號量編程

對于 Linux來說&#xff0c;實際信號是軟中斷&#xff0c;許多重要的程序都需要處理信號。信號&#xff0c;為 Linux 提供了一種處理異步事件的方法。比如&#xff0c;終端用戶輸入了 ctrlc 來中斷程序&#xff0c;會通過信號機制停止一個程序。 信號概述 信號的名字和編號&…

安卓動畫基礎講解

//逐幀動畫 /** * 1.加入單張圖片 * 2.生成movie.xml整個圖片 * 3.代碼中使用圖片movie.xml */ iv(ImageView) findViewById(R.id.iv);// iv.setImageResource(R.drawable.movie);//為iv加載六張圖片// AnimationDrawable ad(AnimationDrawable) iv.getDrawable();//得到圖片給…

JS一些常用的類庫

一、返回上一頁&#xff08;history&#xff09;發覺有兩種用法&#xff1a;1、javascript:history.back(-1);2、javascript:history.go(-1);它們倆的區別是&#xff1a;history.back(-1):直接返回當前頁的上一頁&#xff0c;數據全部消息&#xff0c;返回新頁面history.go(-1)…

Linux上線程開發API概要(線程)

進程與線程 典型的UNIX/Linux進程可以看成只有一個控制線程&#xff1a;一個進程在同一時刻只做一件事情。有了多個控制線程后&#xff0c;在程序設計時可以把進程設計成在同一時刻做不止一件事&#xff0c;每個線程各自處理獨立的任務。 進程是程序執行時的一個實例&…

Redis學習筆記1-Redis數據類型

Redis數據類型 Redis支持5種數據類型&#xff0c;它們描述如下&#xff1a; Strings - 字符串 字符串是 Redis 最基本的數據類型。Redis 字符串是二進制安全的&#xff0c;也就是說&#xff0c;一個 Redis 字符串可以包含任意類型的數據&#xff0c;一個字符串最大為 512M 字節…

30個非常有趣的404錯誤頁面設計欣賞

當用戶訪問一個不存在的頁面的時候就會出現404錯誤頁面&#xff0c;這對用戶來說是很不友好的。所以很多網站都會去設計一個新穎的錯誤頁面&#xff0c;以吸引用戶繼續瀏覽其它的網頁內容。今天這篇文章就收集了30個非常有趣的404錯誤頁面設計欣賞&#xff0c;希望能帶給你靈感…

線程同步之互斥量加鎖解鎖 死鎖

與互斥鎖相關API 互斥量&#xff08;mutex&#xff09;從本質上來說是一把鎖&#xff0c;在訪問共享資源前對互斥量進行加鎖&#xff0c;在訪問完成后釋放互斥量上的鎖。對互斥量進行加鎖后&#xff0c;任何其他試圖再次對互斥量加鎖的線程將會被阻塞直到當前線程釋放該互…

游戲開發-從零開始 002

個人開發者的游戲大部分需要完成的內容&#xff1a; 1.完整的游戲玩法邏輯&#xff08;核心&#xff09; 2.UI 3.游戲關卡設計 4.游戲旁白 5.交互細節 6.游戲分享接口 7.游戲道具 8.游戲排行榜&#xff0c;游戲社區&#xff0c;如 GameCenter 9.游戲內購 如 remove Ads 10.廣告…

5 個最佳的 Linux 桌面環境

打算把每個桌面都試用一遍&#xff0c;但是那很費時間&#xff0c;而且確實有很多桌面環境可供選擇&#xff0c;這就是我發表“最優秀的 Linux 桌面以及他們的優缺點”的目的&#xff0c;本文告訴你在選擇桌面時需要注意些什么&#xff0c;讓我們開始吧。1. KDE我想從第五個說起…

線程條件控制實現線程的同步

與條件變量相關API 條件變量是線程另一可用的同步機制。條件變量給多個線程提供了一個會合的場所。條件變量與互斥量一起使用時&#xff0c;允許線程以無競爭的方式等待特定的條件發生。 條件本身是由互斥量保護的。線程在改變條件狀態前必須首先鎖住互斥量&#xff0c…

自定義能夠for each的類,C#,Java,C++,C++/cli的實現方法

自定義類能夠被for each&#xff0c;應該算是個老生常談的話題了&#xff0c;相關的資料都很多&#xff0c;不過這里整理總結主流語言的不同實現方式&#xff0c;并比較部分細節上的差異。 第一種語言&#xff0c;也是實現起來最簡單的Java語言。在Java里&#xff0c;要被for e…

SQL Server 2008 R2:快速清除日志文件的方法

本例&#xff0c;快速清理“students”數據庫的日志&#xff0c;清理后日志文件不足1M。USE [master] GO ALTER DATABASE students SET RECOVERY SIMPLE WITH NO_WAIT GO ALTER DATABASE students SET RECOVERY SIMPLE GO USE students GO--此處需要注意&#xff…

linux網絡編程之字節序

進程間通信 特點&#xff1a;依賴于內核&#xff0c;造成缺陷——無法實現多機通信。 網絡編程 地址&#xff1a;由IP地址和端口號構成&#xff0c;端口號用來判斷客戶端接入哪個服務器。 數據的交流&#xff1a;涉及到協議&#xff08;http&#xff0c;tcp&#xff0c;udp&…

Oracle查看表空間和表空間中的對象

select * from user_tables;--查詢所有用戶表 select username,default_tablespace from user_users;--查詢當前表空間select tablespace_name from dba_tablespaces;--查詢所有表空間select tablespace_name, sum(bytes)/1024/1024 from dba_data_files group by tablespace_n…

C#中DateTime.Ticks屬性及Unix時間戳轉換

DateTime.Ticks&#xff1a;表示0001 年 1 月 1 日午夜 12:00:00 以來所經歷的 100 納秒數&#xff0c;即Ticks的屬性為100納秒&#xff08;1Ticks 0.0001毫秒&#xff09;。Unix時間戳&#xff1a;是從1970年1月1日&#xff08;UTC/GMT的午夜&#xff09;開始所經過的秒數&am…

WebBrowser控件的常用方法、屬性和事件

1. 屬性屬性說明Application如果該對象有效&#xff0c;則返回掌管WebBrowser控件的應用程序實現的自動化對象(IDispatch)。如果在宿主對象中自動化對象無效&#xff0c;這個程序將返回WebBrowser 控件的自動化對象Parent返回WebBrowser控件的父自動化對象&#xff0c;通常是一…