想要PySide写的桌面应用程序进程间同步有什么已经公认好的设计方案吗?
也就说,比如有多个桌面应用,想要进程间实时同步数据状态信息。
比如:在PySide应用A上做了操作更改了数据A,那么PySide应用B马上有更新显示。
在现有的产品案例中,比如:Adobe系列的产品(Photoshop, Premierer, AfterEffect)。
有一个需求:
做视频的剪辑(Premierer)主线任务,现在需要一个特效场景的素材(AffterEffect实现后,Premierer才有此素材),然而AffterEffect要做此特效素材,需要PhotoShop进行协助。
所以,这是3个不同的应用之间进行通信,协作才能完成的任务。也就是说功能是:应用A更新内容后,应用B马上能获取到信息。
请求这种一般是怎么实现的?
python有pyrpc,先试试看.
基于IPC机制的间接通信
原理: IPC(Inter-Process Communication)机制是进程间通信的通用方法。PySide可以利用操作系统提供的IPC机制,如共享内存、消息队列、管道等,来实现进程间的通信。
常用方法:
共享内存: 多个进程共享一块内存区域,可以高效地进行数据交换。
消息队列: 一个进程向队列中写入消息,另一个进程从队列中读取消息。
套接字: 基于网络的通信方式,可以实现跨机器的进程间通信。
优点: 灵活、高效,适用于复杂的通信场景。
缺点: 实现相对复杂,需要考虑同步、数据序列化等问题。
搜索 进程间通信 字样
公认的方案就是进程间通讯,就那五个
推荐新泻一个控制程序,来进行三个程序间的管控
消息中间件,比如NATS