gpt4 book ai didi

java - 如何将 thrift 对象转换为可读字符串并将其转换回来?

转载 作者:行者123 更新时间:2023-11-30 10:59:55 28 4
gpt4 key购买 nike

有时候,我们需要在单元测试中创建一些thrift对象。我们可以通过使用 Java 代码手动创建对象来实现,例如:

MyObj myObj = new MyObj();
myObj.setName("???");
myObj.setAge(111);

但是这不方便。我正在寻找一种方法来创建带有一些可读文本的对象。

我们可以使用 TSimpleJSONProtocol 将 thrift 对象转换为 JSON,并获得非常易读的 JSON 字符串,例如:

{ "name": "???", "age": 111 }

但问题是 TSimpleJSONProtocol 是只写的,thrift 无法读回它来构造 MyObj 的实例。

虽然有一个支持序列化和反序列化的TJSONProtocol,但是生成的JSON不可读,它使用非常简化的JSON格式并且缺少大部分字段名称。不方便在测试中构造它。

有什么方法可以将 thrift 对象转换为可读字符串,也可以将其转换回来吗?如果 TSimpleJSONProtocol 支持转换回来,这正是我正在寻找的

最佳答案

Thrift 的主要目标是提供高效 序列化和RPC 机制。你想要的是 - 至少部分 - 与此相反的东西。人类可读的数据结构和机器处理效率在很大程度上是相互矛盾的目标,Thrift 更倾向于后者而不是前者。

您已经了解了TSimpleJsonTJson 协议(protocol)以及它们的优缺点,因此没有太多要补充的内容。唯一要说的是:Thrift 的协议(protocol)/传输栈非常简单。

这种简单性使得可以根据您的特定需求添加另一个协议(protocol),而无需太多或过于复杂的工作。人们甚至可以在短时间内编写一个 XML 协议(protocol)(如果有人真的想要这样的过时软件)。

唯一需要注意的是,Thrift 需要字段 ID 来反序列化数据,尤其是针对您的具体情况。因此,您要么需要将它们存储在数据中,要么需要一些其他机制能够根据字段和结构名称检索该字段 ID。

关于java - 如何将 thrift 对象转换为可读字符串并将其转换回来?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31753659/

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