社区
Linux/Unix社区
帖子详情
*******FIFO 逐行读取 坐等大牛*******
Trinea
2010-01-27 01:59:08
两个进程之间用fifo进行通信,其中一个进程需要按行读取fifo中的内容
操作手册和unix环境高级编程中都说通常用open打开fifo,但是这样的话,就只能用read读取open的fifo,没办法使得每次之读取一行内容
不知道有没有大牛知道怎么逐行读取fifo中的内容
我是想用fopen后再用fgets逐行读取,但是不知道fopen能不能操作fifo,希望知道
能给出点根据
,谢谢哈
...全文
138
6
打赏
收藏
<strong>*******FIFO 逐行读取 坐等大牛*******</strong>
两个进程之间用fifo进行通信,其中一个进程需要按行读取fifo中的内容 操作手册和unix环境高级编程中都说通常用open打开fifo,但是这样的话,就只能用read读取open的fifo,没办法使得每次之读取一行内容 不知道有没有大牛知道怎么逐行读取fifo中的内容 我是想用fopen后再用fgets逐行读取,但是不知道fopen能不能操作fifo,希望知道能给出点根据,谢谢哈
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用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的,不过他自己有一个缓冲区而已
1000多种java算法大全源码包
1000多种java算法大全源码包
最全的C和C++语言笔试面试题汇总
最全的C和C++语言笔试面试题汇总,我大四时候找工作时候他帮上了很多忙,里面的题目经常考到。希望对大家有帮助。
C语言两个简单的存储器管理的页面置换算法(
FIFO
and LRU) Page-Replacement Algorithm
一个先近先出置换算法,一个最近最久未使用算法,模拟一下过程。
/*页面置换算法,先近先出算法,就是个队列操作
*/
#include
#include
#include
#include
//内存可提供的页面的个数
#define MEMERY_PAGE_NUM 3
C#泛型集合及应用:List<T>、HashSet<T>、Dictionary<TKey, TValue>、SortedList<TKey, TValue>、Stack<T>、Queue<T>
要使用泛型集合,需要使用尖括号(例如 List)定义它们,并指定它们将包含的对象的类型。然后,可以使用该集合的属性和方法在代码中操作其元素。//.NET8.0直接为://.NET8.0会提示你直接使用集合添加简化初始化"Hello","World",进一步地,还可以使用泛型集合来实现算法和数据结构,例如排序和搜索。
volley源码解析(二)--Request
类的介绍
在上一篇文章中,我们已经提到volley的使用方式和设计的整体思路,从这篇文章开始,我就要结合具体的源码来给大家说明volley功能的具体实现。 我们第一个要介绍的类是Request
这个一个抽象类,我将Request称为一个请求,通过继承Request
来自定义request,为volley提供了更加灵活的接口。
Linux/Unix社区
23,215
社区成员
74,540
社区内容
发帖
与我相关
我的任务
Linux/Unix社区
Linux/Unix社区 应用程序开发区
复制链接
扫一扫
分享
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章