linux--进程通信--管道通信

IPC是各种进程间通信方式的统称。

进程间通信:是指在不同进程之间传播或交换信息。

IPC的方式通常有:

单机:管道(包括无名管道和命名管道)、消息队列、信号量、共享存储、

多机:Socket、Streams等

1、管道:通常指无名管道,是UNIX系统IPC最古老的形式。

特点:①它是半双工的(数据只能在一个方向上流动),具有固定的读端和写端。

· ②只能用于具有亲缘关系的进程之间的通信(也就是父子进程或者兄弟进程)

③它可以看成是一种特殊的文件,对于它的读写也可以使用普通的read、write等函数。但是它不是普通的文件,并不属于其他任何文件系统,并且只存在于内存中。

管道api

cpp 复制代码
#include <unistd.h>
 
int pipe(int fd[2]);

fd[0]为读而打开,fd[1]为写而打开 0读1写

要关闭管道,只需要将这两个文件描述符关闭即可close(fd[0]);close(fd[1]);

fork:返回值<0表示创建失败;返回值>0,程序为父进程;返回值=0,程序为子进程;

代码:

cpp 复制代码
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <string.h>


int main()
{
	int fd[2];
	int pid;
	int status = 10;	
	char buf[1024]= {0};
	if(pipe(fd) == -1){

		printf("creat pipe failed\n");   

	}
	pid = fork();
	if(pid<0){

		printf("creat child failed\n");


	}
	else if(pid >0){
		sleep(3);
//		wait(&status);
		printf("this is father process\n");
//		printf("child quit child status = %d\n",WEXITSTATUS(status));
		close(fd[0]);
		write(fd[1],"qing yuan henshuai from father",strlen("qing yuan henshuai from father"));
		wait(&status);
		printf("child quit child status = %d\n",WEXITSTATUS(status));


	}
	else{

		printf("this is child process\n");
		close(fd[1]);
		read(fd[0],buf,1024);
		printf("read from father:%s\n",buf);
		exit(0);
	}



	return 0 ;
}

结果:

相关推荐
写代码的学渣18 分钟前
Linux云计算个人学习总结(一)
linux·运维·云计算
别NULL25 分钟前
《现代网络技术》读书笔记:SDN数据平面和OpenFlow
linux·网络·平面·sdn
没有名字的小羊39 分钟前
二.Linux文件与目录管理
linux·运维·服务器
头真的要秃啦1 小时前
Linux 无名管道
linux·运维·算法
Diamond技术流1 小时前
从0开始学习Linux——远程连接工具
linux·学习·centos·ssh·xshell·ftp
陌上花开缓缓归以1 小时前
linux strace 查看程序异常问题总结
linux·运维·服务器
wowocpp1 小时前
ubuntu 22.04 防火墙 ufw
linux·运维·ubuntu
zybox运维1 小时前
Linux服务管理-DHCP
linux·运维·服务器
橘色的喵2 小时前
Linux编程:DMA增加UDP 数据传输吞吐量并降低延迟
linux·udp·dma·网络驱动·低延迟·吞吐量·nic
23zhgjx-zgx2 小时前
以太网交换安全:DHCP Snooping
linux·服务器·网络·安全·华为