设为首页
收藏本站
用户名
Email
自动登录
找回密码
密码
登录
注册
快捷导航
平台
Portal
论坛
BBS
文库
项目
群组
Group
我的博客
Space
搜索
搜索
热搜:
shell
linux
mysql
本版
用户
LinuxSir.cn,穿越时空的Linuxsir!
»
论坛
›
编程开发讨论区 —— LinuxSir.cn
›
Linux 程序设计专题讨论
›
求教:两个进程间大量数据传输的解决方法 ...
返回列表
查看:
895
|
回复:
3
求教:两个进程间大量数据传输的解决方法
[复制链接]
yfwill
yfwill
当前离线
积分
94
IP卡
狗仔卡
发表于 2006-6-16 11:11:45
|
显示全部楼层
|
阅读模式
两个进程时间,大量的长时间的数据传输。传输过程中,可能时而数据量特别大,时而数据量特别小。接收端,需要实时判断是否有数据传入,如果有责进行处理。
有人建议我用共享内存,但是当数据量过大的时候,可能造成数据堆积,我怕会造成内存消耗过度。
有没有这样一个方法:在数据量较小或者适中的时候,接收方能够及时处理。当数据量较大的时候,能够缓存到硬盘。而对于接收方,都面向一个唯一的接口,不需要考虑读取的数据来自内存还是硬盘。
请各位指点。
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
显身卡
x11
x11
当前离线
积分
2823
IP卡
狗仔卡
发表于 2006-6-17 10:44:54
|
显示全部楼层
你不是自己已经想出方法来了么?呵呵
回复
支持
反对
使用道具
举报
显身卡
dimensioll
dimensioll
当前离线
积分
18
IP卡
狗仔卡
发表于 2006-6-20 10:27:57
|
显示全部楼层
输出重定向至某个临时文件好了,另一端从该文件读入。
就是简单的文件共享而已(处理好一致性问题)。
“接收端,需要实时判断是否有数据传入,如果有责进行处理。”--->用lseek(fd,0,SEEK_CUR)得到当前offset与文件节点inode->current file size比较,就得到是否有新数据。
回复
支持
反对
使用道具
举报
显身卡
newroot
newroot
当前离线
积分
220
IP卡
狗仔卡
发表于 2006-6-20 11:37:59
|
显示全部楼层
看这种方法行不行
程序分成三部分,A一个提供数据源,直接写入文件
有一个进程B,把数据从文件中读出,然后通过共享内存方式与进程C进行数据传输
这样数据的写入与发送各读取都分开!
回复
支持
反对
使用道具
举报
显身卡
返回列表
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
注册
本版积分规则
发表回复
回帖后跳转到最后一页
浏览过的版块
Gentoo Linux
硬件设备 Linux 驱动
Redhat/Fedora/CentOS Linux
Copyright © 2002-2023
LinuxSir.cn
(http://www.linuxsir.cn/) 版权所有 All Rights Reserved.
Powered by
RedflagLinux!
技术支持:
中科红旗
|
京ICP备19024520号
快速回复
返回顶部
返回列表