文档章节

进程间的通信

成长中的小白
 成长中的小白
发布于 2014/11/24 09:18
字数 825
阅读 5
收藏 0
点赞 0
评论 0

    如果通过文件实现进程间通信一来影响程序运行速度,二来要关注的细节过多,开发调试不方便,而且严重依赖文件系统中的文件,容易造成软件运行的不稳定性。

    

管道是在基本的文件形式的进程间通信的基础上的一个机制,就像在进程之间架设了一个“管道”,一个管道在两个进程间架设的通信是单向的,总是从一个进程将数据输送到另一个进程。

特点1管道使用文件描述符来进行操作;

特点2:一个管道对应两个文件描述符,这两个文件描述符分别表示管道的入口出口”。

特点3:数据传输的特点是FIF0First In First Out

特点4如果管道数据为空,则读数据会阻塞(默认设置如果管道为满时,则写入数据方则阻塞(默认设置)。

特点5管道实现的进程间的通信一定是父子进程之间(爷孙进程之间)。

 

 int pipe(int filedes[2]);  建立管道函数

    pipe()会建立管道,并将文件描述符由参数fiedes数组返回,filedes[0]为管道里的读取段,filedes[1]则为管道的写入端

    返回值:成功则返回0,否则返回-1


FILE *popen(const char *command,const char *type);

    函数声明:popen()会调用fork()产生子进程,然后从子进程中调用/bin/sh -c来执行参数command的指令。type可以使用"r"表示读取,"w"表示写入。按照这个type值,popen()会建立管道连接到子进程的标准输入或标准输出,然后返回一个指针文件。

    返回值:成功则返回文件指针,否则返回NULL。

int pclose(FILE *stream)

    函数说明:pclose()用来关闭由popen()所建立的管道及文件指针。参数Stream为先前由popen所返回的文件指针

    返回值:返回子进程的结束状态。如果有错误则返回-1.

    

参考代码:


#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>

int testPipe(void)
{
    pid_t pid;
    char buff[128];
    int i = 0,ret;
    int fds[2],fps[2];

    ret = pipe(fds);
    if(ret < 0)
    {
        printf("fds初始换管道失败\n");
        exit(-1);
    }
    ret = pipe(fps);
    if(ret < 0)
    {
        printf("初始换fps管道失败\n");
        exit(-1);
    }

    pid = fork();
    if(0 == pid)
    {
        close(fds[1]);
        close(fps[0]);
        while(1)
        {
            ret = read(fds[0],buff,sizeof(buff));
            if(ret < 0)
            {
                printf("读出数据失败\n");
                exit(-1);
            }
            fflush(stdout);
            printf("%s",buff);
            //pause();
            sleep(1);

            sprintf(buff,"我是父进程的第 %d 次输出\n",i);
            fflush(stdout);
            ret = write(fps[1],buff,strlen(buff));
            if(ret < 0)
            {
                printf("管道fps写入失败\n");
                exit(-2);
            }
            i++;
            sleep(1);
        //    pause();
        }
    }else if(pid > 0)
    {
        close(fds[0]);
        close(fps[1]);
        while(1)
        {
            sprintf(buff,"这是子进程第 %d 次输出\n",i);
            fflush(stdout);
            ret = write(fds[1],buff,strlen(buff));
            if(ret < 0)
            {
                printf("写入数据失败\n");
                exit(-1);
            }

            sleep(1);
            i++;
        //    pause();
            

            ret = read(fps[0],buff,sizeof(buff));
            if(buff < 0)
            {
                printf("fps管道读出失败\n");
                exit(-2);
            }
            fflush(stdout);
            printf("%s",buff);
            sleep(1);
        }
    }else
    {
        printf("fork()失败\n");
        return 0;
    }
}

int testPopen()
{
    char buff[512];
    FILE *fp = popen("ls -a","r");

    if(fp == NULL)
    {
        printf("函数popen执行失败\n");
        exit(-1);
    }

    while(fgets(buff,sizeof(buff),fp) > 0)
    {
        puts(buff);
    }
}

int main(void)
{
//    testPipe();

    testPopen();
    return 0;
}

            


© 著作权归作者所有

共有 人打赏支持
成长中的小白
粉丝 0
博文 17
码字总数 11184
作品 0
深圳
程序员
20.进程与线程通信方式之间的差异

进程线程通信方式之间的差异 每个进程有自己的地址空间。两个进程中的地址即使值相同,实际指向的位置也不同。进程间通信一般通过操作系统的公共区进行。 同一进程中的线程因属同一地址空间,...

u014590757 ⋅ 04/16 ⋅ 0

进程间、线程间通信方式

一、进程间的通信方式 (1)管道( pipe ):管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系通常是指父子进程关系。 (2)有名管道 (nam...

为了美好的明天 ⋅ 02/07 ⋅ 0

Linux 的 进程/线程 通信方式总结

linux系统中的进程通信方式主要以下几种: PIPE(FIFO) 消息队列 信号量(Semaphore) 共享存储 SOCKET 同一主机上的进程通信方式 UNIX进程间通信方式: 包括管道(PIPE), 有名管道(FIFO), 和信号(...

xrzs ⋅ 2012/10/05 ⋅ 0

UNIX网络编程卷2进程间通信读书笔记汇总

UNIX网络编程卷2进程间通信读书笔记(一)—概述 http://blog.chinaunix.net/u/22935/article527112.html UNIX网络编程卷2进程间通信读书笔记(二)—管道 (1) http://blog.chinaunix.net/...

长平狐 ⋅ 2012/09/03 ⋅ 0

进程间的通信之主要的几种通信方式

进程间的通信实际上就是在不同的进程之间传播或者交换信息,不同进程之间需要一些互相访问的介质,进程的用户空间是相互独立的,一般而言是不能互相访问的,唯一的例外是共享内存区,按时系统...

苹果与牛顿 ⋅ 2017/10/20 ⋅ 0

Linux进程间通信(一)---进程间通信概述及其种类

为什么会有进程间通信? 我们应该都知道了,进程是一个程序的一次执行,是系统资源分配的最小单元。这里所说的进程一般是指运行在用户态的进程,而由于处于用户态的不同进程间是彼此隔离的,...

长平狐 ⋅ 2013/06/17 ⋅ 0

进程间通讯的方式

管道( pipe ): 管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系通常是指父子进程关系。 有名管道 (named pipe) :有名管道也是半双工的...

旋转木马-千里马 ⋅ 2015/12/29 ⋅ 0

进程间通信的方式及比较

进程间通信就是在不同进程之间传播或交换信息,那么不同进程之间存在着什么双方都可以访问的介质呢?进程的用户空间是互相独立的,一般而言是不能互相访问的,唯一的例外是共享内存区。但是,...

willis_sun ⋅ 2017/03/31 ⋅ 0

深刻理解Linux进程间通信(IPC)

linux下的进程通信手段基本上是从Unix平台上的进程通信手段继承而来的。而对Unix发展做出重大贡献的两大主力AT&T的贝尔实 验室及BSD(加州大学伯克利分校的伯克利软件发布中心)在进程间通信...

墙头草 ⋅ 2010/11/19 ⋅ 0

进程间通信方式总结

几种进程间通信方式: 1:管道:管道是一种半双工的通信方式,数据只能单向流动,而且只能具有亲缘关系的进程间使用。进程的亲缘关系通常指的是父子进程关系。 #include<unistd.h> int pipe(...

DragonRiver2015 ⋅ 2014/05/17 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

JAVA RMI

什么是JAVA RMI Java RMI (Remote Method Invocation) 远程方法调用,能够让客户端像使用本地调用一样调用服务端 Java 虚拟机中的对象方法。RMI 是面向对象语言领域对 RPC (Remote Proced...

saulc ⋅ 12分钟前 ⋅ 0

Linux系统工程狮养成记

如今的社会,随着时代的发展,出现了很多职业,像电子类,计算机类的专业,出现了各种各样的工程师,有算法工程师,java工程师,前端工程师,后台工程师,Linux工程师,运维工程师等等,不同...

linux-tao ⋅ 22分钟前 ⋅ 0

进入编辑模式 vim命令模式 vim实践

1.

oschina130111 ⋅ 22分钟前 ⋅ 0

mysql用户管理、常用sql语句、mysql数据库备份恢复

1. mysql用户管理 mysql默认有一个root超级管理员账户,实际工作环境中不可能每个人都用此root权限,防止误操作、误删除,可以给单独的用户进行授权。 Mysql创建用户以及授权: grant all on...

laoba ⋅ 23分钟前 ⋅ 0

类型后面三个点(String...)和数组(String[])的区别

类型后面三个点(String…),是从Java 5开始,Java语言对方法参数支持一种新写法,叫可变长度参数列表,其语法就是类型后跟…,表示此处接受的参数为0到多个Object类型的对象,或者是一个Obj...

流氓兔- ⋅ 29分钟前 ⋅ 0

JEPLUS表格组件之表格合并——JEPLUS软件快速开发平台

JEPLUS表格组件之表格合并 我们在列表配置时会遇见这样的一种情况,需要对个人的数据进行统一化,对一些数据进行归类,这样展示出来美观又直观,在这篇笔记中我来给大家介绍下如何配置出来专...

JEPLUS ⋅ 30分钟前 ⋅ 0

golang 并发中全局唯一操作

package main// go 携程共享 数据// 加锁解锁操作// 同步锁import ("sync""fmt")// 创建Once结构var once = sync.Once{}func computed(data *int, lock *sync.Mut...

304158 ⋅ 30分钟前 ⋅ 0

Mobx入门之二:asynchronous actions

这一节主要看mobx怎么实现asynchronous actions 1 要实现的demo功能 输入地名,查询天气,利用openweathermap api 2 思想 observable观察数据:location地点、temperature温度 observer响应式...

pengqinmm ⋅ 33分钟前 ⋅ 0

【2018.0620学习笔记】【linux高级知识 13.4-13.6】

13.4 mysql用户管理 创建用户并授权: grant all on *.* to '用户名'@'ip' identified by '密码' //all是操作权限,*.*是库.表,指定格式是'用户名'@'localhost'才能用socket登录本地 gra...

lgsxp ⋅ 54分钟前 ⋅ 0

Java强弱引用示例

package jdk;import java.lang.ref.PhantomReference;import java.lang.ref.ReferenceQueue;import java.lang.ref.SoftReference;import java.lang.ref.WeakReference;public ......

月下狼 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部