管道的读写操作

读:

#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define FIFO "/tmp/myfifo"
main(int argc,char** argv)
{
char buf_r[100];
int  fd;
int  nread;
/* 创建管道 */
if((mkfifo(FIFO,O_CREAT|O_EXCL)<0)&&(errno!=EEXIST))
printf("cannot create fifoserver\n");
printf("Preparing for reading bytes...\n");
memset(buf_r,0,sizeof(buf_r));
/* 打开管道 */
fd=open(FIFO,O_RDONLY|O_NONBLOCK,0);
if(fd==-1)
{
perror("open");
exit(1);
}
while(1)
{
memset(buf_r,0,sizeof(buf_r));
if((nread=read(fd,buf_r,100))==-1)
{
if(errno==EAGAIN)
printf("no data yet\n");
}
printf("read %s from FIFO\n",buf_r);
sleep(1);
}
pause(); /*暂停,等待信号*/
unlink(FIFO); //删除文件
}
写:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <memory.h>
#include <stdlib.h>
#define FIFO_SEVER "/tmp/fifosever"
int main(int argc,char *argv[])
{
    int fd;
    char w_buf[4096*2];
    int real_wnum;
    memset(w_buf,0,4096*2);
    if((mkfifo(FIFO_SEVER,O_CREAT|O_EXCL) < 0) && (errno != EEXIST))
    {
        printf("cannt create fifosever!\n");
        exit(0);
    }
    fd = open(FIFO_SEVER,O_WRONLY|O_NONBLOCK);
    if(fd == -1)
    {
        if(errno == ENXIO)
            printf("open error,no reading process\n");
    }
    scanf("%s",w_buf);
    real_wnum = write(fd,w_buf,2048);
    if(real_wnum == -1)
    {
        if(errno == EAGAIN)
        {
            printf("write to fifo error try later!\n");
        }
    }
    else
    {
        printf("real write num is %d\n",real_wnum);
    }
    return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用无名管道进行读写操作之前,需要先创建一个无名管道。可以使用以下代码创建一个无名管道: ``` int fd[2]; int ret = pipe(fd); ``` 这将创建一个无名管道,并将读端口的文件描述符存储在fd[0]中,将写端口的文件描述符存储在fd[1]中。接下来,可以使用这些文件描述符进行读写操作。 例如,以下代码演示了如何在子进程中向父进程写入数据,并在父进程中读取数据: ``` #include <stdio.h> #include <stdlib.h> #include <unistd.h> int main() { int fd[2]; int ret = pipe(fd); if (ret == -1) { perror("pipe failed"); exit(1); } pid_t pid = fork(); if (pid == -1) { perror("fork failed"); exit(1); } else if (pid == 0) { // 子进程写入数据 close(fd[0]); // 关闭读端口 int data = 12345; write(fd[1], &data, sizeof(data)); close(fd[1]); // 写完数据后关闭写端口 exit(0); } else { // 父进程读取数据 close(fd[1]); // 关闭写端口 int data; read(fd[0], &data, sizeof(data)); printf("Received data: %d\n", data); close(fd[0]); // 读完数据后关闭读端口 exit(0); } } ``` 在上面的代码中,首先创建一个无名管道,并使用fork函数创建一个子进程。在子进程中,关闭读端口,然后写入一个整数数据,最后关闭写端口。在父进程中,关闭写端口,然后读取一个整数数据,最后关闭读端口。注意,读写操作是阻塞的,因此父进程会在等待子进程写入数据时阻塞,子进程会在等待父进程读取数据时阻塞。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值