Windows下实现FIFO(先进先出的管道)功能

wdy9927 2010-07-20 11:51:39
在linux下使用mkfifo创建的文件属于fifo,两个进程对这个fifo操作,一个进程写,一个进程读。
读进程会将刚才写进程写入的东西读出来,而写进程在没有读进程不能往fifo写入,这样就保证了这个fifo文件不会增大。


在windows下如何实现这样的功能?

有人说用socket,但这样不就得在本地建一个server一个client?端口也是个麻烦,在程序中写死,一旦在本地端口被占用,怎么办??

...全文
1655 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
ghlpj 2011-11-19
  • 打赏
  • 举报
回复
比本机的SOCKET如何?
wdy9927 2010-08-24
  • 打赏
  • 举报
回复
项目耽搁了,决定用pipe试试。

liyinlei 2010-07-22
  • 打赏
  • 举报
回复
管道 的通讯速率还是很快的,可以达到 几百M/S
liyinlei 2010-07-20
  • 打赏
  • 举报
回复
可以通过 内存映射文件 来实现内存共享 CreateFileMapping MapViewOfFile
一边只写,一边只读。

写完给另一个进程一个事件信号,通知它可以读了, 读的进程同样也可以通过event可以通知写的进程。 使用有名Event就可以了。
Eleven 2010-07-20
  • 打赏
  • 举报
回复
再说了,即使用两个进程去做,进程之间通讯的方式也很多啊,不局限于上面说的那两个
Eleven 2010-07-20
  • 打赏
  • 举报
回复
在linux下使用mkfifo创建的文件属于fifo,两个进程对这个fifo操作,一个进程写,一个进程读。
读进程会将刚才写进程写入的东西读出来,而写进程在没有读进程不能往fifo写入,这样就保证了这个fifo文件不会增大。
--------------------------------------------
你为什么不在同一个进程的两个线程中去做读和写的操作呢?为什么要放到两个进程中去做呢?
wdy9927 2010-07-20
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 liyinlei 的回复:]

可以用管道 Pipe, 或是用消息队列MSMQ
[/Quote]
是音视频数据,数据量非常大,恐怕不行吧,并且是2个进程。



[Quote=引用 4 楼 visualeleven 的回复:]

在服务上的socket通讯端口一般都是规定好的,不会随意修改的
[/Quote]
2个进程都在本地,所以端口可以指定,就怕在本地被占用。
Eleven 2010-07-20
  • 打赏
  • 举报
回复
在服务上的socket通讯端口一般都是规定好的,不会随意修改的
liyinlei 2010-07-20
  • 打赏
  • 举报
回复
可以用管道 Pipe, 或是用消息队列MSMQ
wdy9927 2010-07-20
  • 打赏
  • 举报
回复
可是,我的client端不知道被分配的端口是什么。

两个进程,没法通知。

Eleven 2010-07-20
  • 打赏
  • 举报
回复
端口你可以写addr.sin_port = 0就可以了,socket会选择一个未被占用的端口来是使用
liyinlei 2010-07-20
  • 打赏
  • 举报
回复
要做缓存。 这些是如何通讯的技术, 怎么保证读写是自己来做逻辑。

UDP和 内存共享都是可以保证通讯大数据量的。
wdy9927 2010-07-20
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 visualeleven 的回复:]

在linux下使用mkfifo创建的文件属于fifo,两个进程对这个fifo操作,一个进程写,一个进程读。
读进程会将刚才写进程写入的东西读出来,而写进程在没有读进程不能往fifo写入,这样就保证了这个fifo文件不会增大。
--------------------------------------------
你为什么不在同一个进程的两个线程中去做读和写的操作呢?为什么要放到两个进程中……
[/Quote]
是两个独立的程序
实际上一个程序是音视频采集,另一个是播放器。
不想让音视频采集的程序与播放器有任何的联系,因为播放器是可能换的。



[Quote=引用 8 楼 liyinlei 的回复:]

可以通过 内存映射文件 来实现内存共享 CreateFileMapping MapViewOfFile
一边只写,一边只读。

写完给另一个进程一个事件信号,通知它可以读了, 读的进程同样也可以通过event可以通知写的进程。 使用有名Event就可以了。
[/Quote]
音视频数据量非常大,并且在不断的写,恐怕不行。在读的时候,又写进来了。

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧