linux 管道
来源:互联网 发布:java linux cpu使用率 编辑:程序博客网 时间:2024/06/05 06:03
原创:http://blog.sina.com.cn/u/2312748742
一、进程间通信的目的:
1、数据传输,2、共享数据,当一个进程对共享资源修改时,别的进程应该看到。3、通知时间,一个进程向另一个进程通知发生了某种事件。4、资源共享,多个资源共享同样的资源,需要内核提供锁和同步机制,5、进程控制,有些进程希望完全控制另一个进程的自行,如Debug,他可以拦截另一个进程所有陷入和异常,能及时制定它的状态改变。
二、linux使用的进程间的通信:
1、管道(pipe)和命名管道(FIFO),2、信号,3、信息对列。4、共享内存。5、信号量(与信号不同),主要实现进程间的通信,如互斥量。6、套接字网络编程
三、管道:
1、管道式半双工的。只能用于父子进程或者兄弟之间的通信,通常一个管道由一个进程创建,然后该进程调用fork,此后父子进程就可以用该管道。
2、包含头文件#include
file_descriptor[0]表示读端,file_descriptor[1]表示写端。
3、例如:
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define ERR_EXIT(m) do\
{\
} while (0);
int main()
{
}
结果显示:recv from child process:hello this is child process!
。
-------------------------------------------------
命名管道:
fifo文件,命名管道可以用于不同进程间的通信。
命名管道的创建用#
可以往mypipe里面输入内容,如ls -l > mypipe
管道不能用O_RDWR打开,应该他是单项的,可以用open打开,1、如果当前打开的操作为读而打开FIFO时,若已经有相应的进程为写而打开该FIFO,则当前的打开操作则成功返回;否则可能阻塞直到有相应的进程为写而打开该FIFO(当前打开操作设置的阻塞标准为O_RDONLY,,反之如果当前打开操作设置非阻塞标准即:O_NONBLOCK,则返回成功);2、如果当前打开操作为写而打开FIFO,如果已经有相应的进程为读而打开该fifo,则当前打开操作成功返回,否则可以阻塞直到有相应的进程为读而打开该fifo(当前设置了阻塞标志)
include<unistd.h>
#include<stdlib.h>
#in#clude<stdio.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<errno.h>
#include<sys/wait.h>
#include<signal.h>
#include<string.h>
#define ERR_EXIT(m) do\
{\
}while(0)
int main()
{
}
运行此程序,在另一个终端输入 ls - >mypipe即可看到现象
- linux 管道
- Linux pipe(管道)
- Linux 上实现双向进程间通信管道
- Linux环境进程间通信(一): 管道及有名管道
- linux 管道
- linux管道
- Linux 管道
- Linux 管道
- Linux管道
- linux管道
- linux管道
- Linux管道
- linux管道
- linux管道
- linux管道
- linux 管道
- linux管道
- linux管道
- vector当使用at时抛出异常时进行捕…
- ARM335X参考手册 中文
- 如何单步调试 dll 文件里面函数
- linux 信号
- 2013年04月10日
- linux 管道
- ios 程序在后台运行
- ActiveX
- AM335X uboot烧写
- 进程 fork
- DM36x之 RBL->UBL->U-BOOT
- 编译DM36X的UBL,
- DM368 NAND Flash启动
- DM368 ubl和uboot的裁剪