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