gpt4 book ai didi

perl - 是否有理由不使用 Storable 或 YAML 序列化我的(Moose)对象?

转载 作者:行者123 更新时间:2023-12-05 01:34:23 26 4
gpt4 key购买 nike

我有一些 Moose 对象和其他一些我想序列化的简单哈希对象(哈希、数组)。

起初,我使用了一个简单的

my $obj_store_file = nstore($obj);


my $obj = retrieve($obj_store_file);

这工作得很好。

后来,我找到了关于 MooseX::StorageKiokuDB .我尝试使用它们来享受它们的一些好处,但是:
  • MooseX::Storage似乎重新创建了多次引用的对象。例如,我的一个序列化对象包含一些属性,每个属性都引用另一个对象的同一个实例。在序列化之前,所有这些引用显然是相同的——它们都指向同一个对象。使用 MooseX::Storage 进行序列化/反序列化后,这个曾经的单个对象被复制,每个引用都指向该对象的另一个实例。有人告诉我 MooseX::Storage不适合表示对象图,我可能想尝试 KiokuDB .
  • 我做了,虽然我觉得KiokuDB对我的需求来说太过分了。我不需要数据库可以提供的所有花哨的东西。不幸的是,由于我的一个对象非常大并且在使用默认值进行序列化时会占用内存,因此我似乎必须编写自定义序列化程序或单独存储其“数据”部分,然后编写服装 KiokuX::Module ...再次,相当矫枉过正。

  • 所以,我又回到了普通的 ol' Storable 或 YAML。我的问题很简单:是的, KiokuDB 有一些好处。 (尤其是它维护一个对象图的事实),也许还有 MooseX::Storage (虽然我真的找不到后者)。但是,鉴于这些好处对我来说并没有真正的用处,是否有任何理由 不是 使用可存储或 YAML?

    换句话说,以这种方式存储(Moose)对象有什么问题吗?是否“违法”?

    最佳答案

    我的经验是,这取决于您为什么要序列化数据。我喜欢可存储的程序状态,包括窗口大小/位置等内容。我更喜欢 YAML 用于配置数据或您可能想与应用程序的另一个副本交换的任何内容。 (即用户之间共享——使用不同版本的 Perl 或 Storable 的用户可能无法读取 Storable 文件。)Storable 支持对象图(假设卡住/解冻正确完成)。我不确定 YAML。

    关于perl - 是否有理由不使用 Storable 或 YAML 序列化我的(Moose)对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4030373/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com