多进程间使用共享内存进行通讯

在写一个项目中,有一个进程是信息显示进程,其他的进程错误消息或通知消息会传到信息显示进程中,信息显示窗口显示出来。

如果使用socket进行信息传递可行。把信息显示窗口作为服务端,产生信息的进程作为客户端。

如果使用共享内存进行通信,就有些问题,可能是我本人水平有限。先写下来慢慢解决。

一    一个进行写信息,一个进程读信息

如何做到这两个进程间同步,想到的办法是,在每条信息的前面加个标志位,例如1代表可写,0代表可读。

写进程先判断标志位如果是1代表可写,那么就在该内存中写入信息,写完后把该标志位改成0,表示这读进程可读

如果判断是0就代表不可写,就继续判断下一个内存的标志位。

而读进程相反。

这种方法不会造成读写冲突。

二  多个进程写信息,一个进程读信息

这个情况如果使用上个方法就会造成写冲突。

当一个写进程判断了标志位是1时可写,准备写时,该进程的时间片到了,另一个写进程也执行到了这个地方,也判断了标志位是1,于是造成了多个写进程同时写一个内存的状况。

这个问题怎么解决呐。目前还没有想出来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值