zoukankan      html  css  js  c++  java
  • 有名管道通讯编程

    创建2个进程,在A进程中创建一个有名管道,并向其写入数据,通过B进程从有名管道中读出数据。

    有名管道又称命名管道,可用于无亲缘关系的进程之间通信,在某些特点上类似于文件。

    用法:通过mkfifo创建有名管道,之后就可以想操作普通文件通过open()、close()、write()、以及read()对它进行相应操作。

    1、创建一个有名管道--mkfifo

    头文件:#include<sys/types.h>,#include<sys/stat.h>

    原型:int mkfifo(const char *pathname,mode_t mode);

    参数说明:pathname:创建有名管道对应的实名文件路径,mkfifo()会依参数建立特殊的FIFO文件,该文件必须不存在,mode:文件的权限。

    返回值:成功返回0,失败返回-1,错误原因存于errno中。

    2、删除有名管道(实质是一个文件)---unlink

    头文件:#include<unistd.h>

    原型:int unlink(const char *pathname);

    参数说明:pathname:有名管道文件路径名

    返回值:成功返回0,失败返回-1,错误原因存于errno中。

    fifo_write.c

     

    fifo_read.c

    total.h

    先执行读

    后执行写

    在这里为什么先执行读,再执行写才能把写入的数据读出来??当先写入数据时,再执行读 是没法读出数据的?为什么?

    注意:

    errno是记录系统的最后一次错误代码,代码是一个int型的值,在errno.h中定义。

    对于参数O_NONBLOCK是非阻塞模式,以open操作为例,就是open以及接下来在这个文件描述符上的操作,都不会让调用进程等待数据到来,而是直接返回EAGAIN。比如你操作一个video camera设备,使用非阻塞模式打开/dev/video,读取数据时,v412 buffer队列有可用数据返回数据,没有可用数据,则立即返回EAGAIN。使用阻塞模式打开/dev/video,当没有数据可用时,则当前进程休眠在这个buffer queue等待队列上,直到新数据到达,唤醒等待队列上的进程才会返回。

    总结:有名管道创建成功后,一个进程以只读方式打开,另一进程以只写方式打开。

  • 相关阅读:
    利用Powerdesigner16.5(64位)连接64位oracle 配置系统odbc驱动
    Commons BeanUtils 中对Map的操作
    java内存模型与线程
    类加载器详解
    虚拟机性能监控与故障处理工具
    ENode框架Conference案例分析系列之
    ENode框架Conference案例分析系列之
    225.优化路径选择
    224.CAD相关操作
    223.概率统计
  • 原文地址:https://www.cnblogs.com/gary-guo/p/5558075.html
Copyright © 2011-2022 走看看