免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6066 | 回复: 6
打印 上一主题 下一主题

对linux下管道, read, fread 的疑问 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-01-05 13:42 |只看该作者 |倒序浏览
小弟写了两个程序来实验popen, 父进程写入数据, 子进程读取数据.
父进程
========================================
#include <stdio.h>

int main (void)
{
    FILE *fp = NULL;
    fp = popen ("./child_reader", "w");
    fprintf (fp,"Hello world\n");
    fflush(fp);
    sleep(10);
    return 0;

}

子进程
========================================
#include <stdio.h>
#include <unistd.h>

int main (void)
{
    char buf[128] = { 0, };
#if 0
    size_t byte_read = 0;
    byte_read = fread (buf, sizeof(buf), 1, stdin);
    buf[byte_read] = '\0';
    printf ("I am child %s\n", buf);
#else
    int byte_read = 0;
    byte_read = read (STDIN_FILENO, buf, sizeof(buf));
    buf[byte_read] = '\0';
    printf ("I am child %s\n", buf);
#endif

    return 0;
}

子进程用read 和 fread 读取管道的数据时候出现了不同的现象.
用read读取的时候, 子进程马上就打出了数据.
而用fread读取的时候, 子进程在fread阻塞直到父进程,  没有打印出父进程写入的数据.


我现在的知识没办法解释这个现象.

论坛徽章:
0
2 [报告]
发表于 2009-01-05 14:13 |只看该作者
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
The function fread reads nmemb elements of data, each size bytes long, from the stream pointed to by steam, storing them at the location given by ptr.

ssize_t read(int fd, void *buf, size_t count);
read() attempts to read up to count bytes from the file descriptor fd into the buffer starting at buf.

仔细体会一下这2个函数的区别

留意一下手册里对read()和fread()系统调用返回情况的说明

[ 本帖最后由 zhuhefang2006 于 2009-1-5 14:34 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2009-01-05 14:16 |只看该作者
而用fread读取的时候, 子进程在fread阻塞直到父进程,  没有打印出父进程写入的数据.

进程在fread阻塞直到父进程 这句话怎么看不懂啊

论坛徽章:
0
4 [报告]
发表于 2009-01-05 14:26 |只看该作者
不好意思, 写错了.  子进程在fread阻塞直到父进程退出

论坛徽章:
0
5 [报告]
发表于 2009-01-05 14:40 |只看该作者
用fread读取的时候, 子进程在fread阻塞直到父进程退出,  没有打印出父进程写入的数据.

其实使用fread的时候,你的fread()出错了你没有检查它的返回值

if ((byte_read = fread (buf, sizeof(buf), 1, stdin)) == 0)
        {
                if (ferror)
                {
                        printf("fread() error\n");
                        exit(0);
                }
                else
                {
                        printf("fread() with end of file\n");
                }
        }

论坛徽章:
0
6 [报告]
发表于 2009-01-05 15:24 |只看该作者
恩fread 会读取到指定数目的数据,  除非end-of-file发生或io-err发生

但是我发现 byte_read 的状态不正常.

比如我在父端写2byte,在子端读2byte, 2字节数据已经被读入buf,但是byte_read却为1而不是2.

论坛徽章:
0
7 [报告]
发表于 2009-01-05 15:32 |只看该作者
不好意思,  是我datasheet看的不够仔细.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP