V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
tanxnative
V2EX  ›  程序员

同一主机,如何减少进程间传递数据的序列化和反序列化?

  •  
  •   tanxnative · 2023-09-19 14:38:53 +08:00 · 1017 次点击
    这是一个创建于 461 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如题,在系统中,多个进程协同处理数据,同一机器中,进程间传递数据如何减少序列化和反序列化?

    6 条回复    2023-09-20 09:36:32 +08:00
    AoEiuV020JP
        1
    AoEiuV020JP  
       2023-09-19 15:04:58 +08:00
    除了减少进程多用线程感觉没有其他方法了,跨进程任何通信都得序列化,只能减少通信次数和内容量,
    TomVista
        2
    TomVista  
       2023-09-19 15:08:09 +08:00
    减弱数据格式.
    lDqe4OE6iOEUQNM7
        3
    lDqe4OE6iOEUQNM7  
       2023-09-19 15:08:37 +08:00
    用共享内存技术,内存队列,共享数据结构
    sujin190
        4
    sujin190  
       2023-09-19 15:13:50 +08:00 via Android
    分配共享内存,使用 c 直接在共享内存分配 struct ,其他高级语言得话加载 c 模块调用,估计应该是最快的了吧
    bianhui
        5
    bianhui  
       2023-09-20 08:54:17 +08:00
    @sujin190 那不是增加了高级语言与 c 模块之间的类型转化吗,而且如果读写频繁,转化次数更多,可能比其语言自己共享内存的方法更慢。
    sujin190
        6
    sujin190  
       2023-09-20 09:36:32 +08:00
    @bianhui #5 似乎 java 、python 这样的高级语言都并不能直接在共享内存分配对象实例吧,所以所谓共享内存要么只能放数字之类的简单对象,复杂对象还是要序列化和反序列化通过共享内存在不同进程间同步的,而且大部分高级语言加载 C 扩展的时候并没有说你一定要转换为自身的类型才能参与逻辑算法吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3387 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 11:36 · PVG 19:36 · LAX 03:36 · JFK 06:36
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.