在写一个项目中有一个进程是信息显示进程,其他的进程错误消息或通知消息会传到信息显示进程中信息显示窗口显示出来。
如果使用socket进行信息传递可行把信息显礻窗口作为服务端,产生信息的进程作为客户端
如果使用释放共享内存存进行通信,就有些问题可能是我本人水平有限。先写下来慢慢解决
一 一个进行写信息,一个进程读信息
如何做到这两个进程间同步想到的办法是,在每条信息的前面加个标志位例如1代表可写,0代表可读
写进程先判断标志位如果是1代表可写,那么就在该内存中写入信息写完后把该标志位改成0,表示这读进程可读
如果判断是0僦代表不可写就继续判断下一个内存的标志位。
这种方法不会造成读写冲突
二 多个进程写信息,一个进程读信息
这个情况如果使用上個方法就会造成写冲突
当一个写进程判断了标志位是1时可写,准备写时该进程的时间片到了,另一个写进程也执行到了这个地方也判断了标志位是1,于是造成了多个写进程同时写一个内存的状况
这个问题怎么解决呐。目前还没有想出来