社区
Linux/Unix社区
帖子详情
*******FIFO 逐行读取 坐等大牛*******
Trinea
2010-01-27 01:59:08
两个进程之间用fifo进行通信,其中一个进程需要按行读取fifo中的内容
操作手册和unix环境高级编程中都说通常用open打开fifo,但是这样的话,就只能用read读取open的fifo,没办法使得每次之读取一行内容
不知道有没有大牛知道怎么逐行读取fifo中的内容
我是想用fopen后再用fgets逐行读取,但是不知道fopen能不能操作fifo,希望知道
能给出点根据
,谢谢哈
...全文
122
6
打赏
收藏
<strong>*******FIFO 逐行读取 坐等大牛*******</strong>
两个进程之间用fifo进行通信,其中一个进程需要按行读取fifo中的内容 操作手册和unix环境高级编程中都说通常用open打开fifo,但是这样的话,就只能用read读取open的fifo,没办法使得每次之读取一行内容 不知道有没有大牛知道怎么逐行读取fifo中的内容 我是想用fopen后再用fgets逐行读取,但是不知道fopen能不能操作fifo,希望知道能给出点根据,谢谢哈
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
6 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
Trinea
2010-02-02
打赏
举报
回复
经自己验证,可以用fopen打开
Trinea
2010-01-28
打赏
举报
回复
??创意
[Quote=引用 3 楼 armed 的回复:]
都是牛x,不过我还是觉得楼主的需求有创意。
[/Quote]
Trinea
2010-01-28
打赏
举报
回复
??创意
[Quote=引用 2 楼 yhh111 的回复:]
ssize_t readline(int fd, void *vptr,size_t maxlen)
{
ssize_t n,rc;
char c,*ptr;
ptr=vptr;
for(n = 1; n < maxlen; n++) {
again:
if( (rc = read(fd,&c,1)) == 1) {
*ptr++ = c;
if (c == '\n')
break;
} else if( rc == 0) {
*ptr = 0;
return (n - 1);
} else {
if ( errno == EINTR)
goto again;
return (-1); //error ,errno set by read()
}
}
*ptr = 0;
return (n);
}
[/Quote]
armed
2010-01-27
打赏
举报
回复
都是牛x,不过我还是觉得楼主的需求有创意。
yuhh666
2010-01-27
打赏
举报
回复
ssize_t readline(int fd, void *vptr,size_t maxlen)
{
ssize_t n,rc;
char c,*ptr;
ptr=vptr;
for(n = 1; n < maxlen; n++) {
again:
if( (rc = read(fd,&c,1)) == 1) {
*ptr++ = c;
if (c == '\n')
break;
} else if( rc == 0) {
*ptr = 0;
return (n - 1);
} else {
if ( errno == EINTR)
goto again;
return (-1); //error ,errno set by read()
}
}
*ptr = 0;
return (n);
}
blackbillow
2010-01-27
打赏
举报
回复
直接用fopen打开然后用fgets读没问题的
即使是用open打开之后,也可以用fdopen处理一下FILE *in = fdopen(fd, "r"), 然后用fgets
其实fgets内部还是用read的,不过他自己有一个缓冲区而已
C语言两个简单的存储器管理的页面置换算法(
FIFO
and LRU) Page-Replacement Algorithm
*/<br /> #include <stdio.h><br /> #include <conio.h><br /> #include <time.h><br /> #include <stdlib.h><br /><br /> //内存可提供的页面的个数<br /> #define MEMERY_PAGE_NUM 3<br
数据结构的Java实现——栈和队列
<br />队列(Queue)作为一个先进先出(
FIFO
) 的线性结构,支持在队首获取元素,在对尾插入元素。<br /> <br />栈的实现:<br /><br /> <br />package ds.linerlist; /** * 栈的实现 * @param <E> * @...
volley源码解析(二)--Request
类的介绍
在上一篇文章中,我们已经提到volley的使用方式和设计的整体思路,...我们第一个要介绍的类是Request<T>这个一个抽象类,我将Request称为一个请求,通过继承Request<T>来自定义request,为volley提供了更加灵活的接口。
H.264学习笔记之二(片及片头语法)
2.4片层句法<br />1片层句法(不分区)<br />句法<br />C<br />Desc<br />slice_layer_without_partitioning_rbsp(){<br /> <br /> <br /> slice_...data() syntax */<br />2|3|4<br /> <br /> rbsp_slice_trail
S3C6410 2D Graphics Driver
S3C6410 2D Graphics Driver2010-04-24 16:23<br />/*****************************************************<br />三星的2D驱动<br />主要实现功能有<br />bitBLT<br />rotate<br />Alpha Blending<br />...
Linux/Unix社区
23,116
社区成员
74,506
社区内容
发帖
与我相关
我的任务
Linux/Unix社区
Linux/Unix社区 应用程序开发区
复制链接
扫一扫
分享
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章