List <hashmap <string,object>&gt; </hashmap <string,object>的Thrift类型建模

时间:2013-12-30 19:11:43

标签: java thrift

我在Java中使用以下返回类型的服务方法:

List<HashMap<String,Object>>

我怎样才能在节俭中最好地塑造它?

2 个答案:

答案 0 :(得分:6)

非常简单:

struct MyObjectData {
    // data of your objects
}

list< map< string, MyObjectData>>

您可能希望将其设为类型:

typedef list< map< string, MyObjectData>>   MyObjectStructure

需要注意的是MyObjectData的数据结构。如果按Object字面意思是任何 Object,那么我们就遇到了问题。 Thrift无法处理这样的通用情况,因为它不支持相互派生的结构(就像你可以使用class)。你可以做的是,使用union持有不同类型的结构,其中一次只使用一个结构:

struct Foo { /* some fields */ }
struct Bar { /* some fields */ }

// a union allows us to store different kinds of structs in one list
union Generic {
  1: Foo foo
  2: Bar bar
}

// technically, a union is more or less a struct with optional fields, 
struct Alternative {
  1: optional Foo foo
  2: optional Bar bar
}

如果您需要派生结构,我通过这样做解决了这个问题:

struct Base { 
    // some fields
}

struct Derived { 
    1: Base base_
    // some more fields
}

对我来说效果很好。如果你有一个深度继承树,它可能会有点痛苦,但在我的特定情况下情况并非如此。

答案 1 :(得分:2)

AFAIK thrift不直接支持通用对象类型,这些类型可以是从您喜欢的任何对象进行类型转换的类型。您必须像上面的示例一样专门定义您的对象。您不能将返回类型作为对象。 这里有一个解决方法: Generic objects in Apache Thrift