You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The serialization mechanism currently calls the ReflectData.get().resolveUnion() Method for resolving union schemas. This call represents a huge penalty as it generates the entire schema for the object behind the scenes to get the schema name and find the corresponding index. It's even worse because sometimes it not even possible to generate the schema for the actual value, causing the serialization to fail:
classFoo {
// The schema for this object cannot be generated, as the type of tricks can be anything.// However, for the sake of the serialization, it doesn't matter, as the type has been specified in the schemapublicSet<?> tricks = newHashSet<>();
}
This issue can be resolved by checking the set of union schema using the class name instead of using ReflectData.get().resolveUnion(). There is already a snippet in the code that does exactly this, but is currently disabled.
The text was updated successfully, but these errors were encountered:
The serialization mechanism currently calls the
ReflectData.get().resolveUnion()
Method for resolving union schemas. This call represents a huge penalty as it generates the entire schema for the object behind the scenes to get the schema name and find the corresponding index. It's even worse because sometimes it not even possible to generate the schema for the actual value, causing the serialization to fail:This issue can be resolved by checking the set of union schema using the class name instead of using
ReflectData.get().resolveUnion()
. There is already a snippet in the code that does exactly this, but is currently disabled.The text was updated successfully, but these errors were encountered: