此内容没有您所选择的语言版本。

6.3.2. The Externalizable API Configuration Example


To configure JBoss Data Grid's Externalizable API:
  • Provide an externalizer implementation for the type of object to be marshalled/unmarshalled.
  • Annotate the marshalled type class using {@link SerializeWith} to indicate the externalizer class.
For example:
import org.infinispan.marshall.Externalizer;
import org.infinispan.marshall.SerializeWith;
 
@SerializeWith(Person.PersonExternalizer.class)
public class Person {
 
   final String name;
   final int age;
 
   public Person(String name, int age) {
      this.name = name;
      this.age = age;
   }
 
   public static class PersonExternalizer implements Externalizer<Person> {
      @Override
      public void writeObject(ObjectOutput output, Person person)
            throws IOException {
         output.writeObject(person.name);
         output.writeInt(person.age);
      }
 
      @Override
      public Person readObject(ObjectInput input)
            throws IOException, ClassNotFoundException {
         return new Person((String) input.readObject(), input.readInt());
      }
   }
}

There are several disadvantages to configuring Externalizers in this manner:
  • The payload size generated using this method can be inefficient due to constraints within the model.
  • An Externalizer can be required for a class for which the source code is not available, or the source code cannot be modified.
  • The use of annotations can limit framework developers or service providers attempting to abstract lower level details, such as marshalling layer.
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2026 Red Hat
返回顶部