Package org.apache.ignite.binary
Interface BinaryObject
- 
- All Superinterfaces:
- Cloneable,- Serializable
 
 public interface BinaryObject extends Serializable, Cloneable Wrapper for binary object in binary format. Once an object is defined as binary, Ignite will always store it in memory in the binary format. User can choose to work either with the binary format or with the deserialized form (assuming that class definitions are present in the classpath).NOTE: user does not need to (and should not) implement this interface directly. To work with the binary format directly, user should create a cache projection over BinaryObjectclass and then retrieve individual fields as needed:IgniteCache<BinaryObject, BinaryObject> prj = cache.withKeepBinary(); // Convert instance of MyKey to binary format. // We could also use BinaryObjectBuilder to create the key in binary format directly. BinaryObject key = ignite.binary().toBinary(new MyKey()); BinaryObject val = prj.get(key); String field = val.field("myFieldName");Alternatively, if we have class definitions in the classpath, we may choose to work with deserialized typed objects at all times. In this case we do incur the deserialization cost.IgniteCache<MyKey.class, MyValue.class> cache = grid.cache(null); MyValue val = cache.get(new MyKey()); // Normal java getter. String fieldVal = val.getMyFieldName(); Working With Maps and CollectionsAll maps and collections in binary objects are serialized automatically. When working with different platforms, e.g. C++ or .NET, Ignite will automatically pick the most adequate collection or map in either language. For example,ArrayListin Java will becomeListin C#,LinkedListin Java isLinkedListin C#,HashMapin Java isDictionaryin C#, andTreeMapin Java becomesSortedDictionaryin C#, etc.Dynamic Structure ChangesSince objects are always cached in the binary format, server does not need to be aware of the class definitions. Moreover, if class definitions are not present or not used on the server, then clients can continuously change the structure of the binary objects without having to restart the cluster. For example, if one client stores a certain class with fields A and B, and another client stores the same class with fields B and C, then the server-side binary object will have the fields A, B, and C. As the structure of a binary object changes, the new fields become available for SQL queries automatically.Building Binary ObjectsIgnite comes withBinaryObjectBuilderwhich allows to build binary objects dynamically:BinaryObjectBuilder builder = Ignition.ignite().binary().builder("org.project.MyObject"); builder.setField("fieldA", "A"); builder.setField("fieldB", "B"); BinaryObject binaryObj = builder.build();For the cases when class definition is present in the class path, it is also possible to populate a standard POJO and then convert it to binary format, like so:MyObject obj = new MyObject(); obj.setFieldA("A"); obj.setFieldB(123); BinaryObject binaryObj = Ignition.ignite().binary().toBinary(obj);Binary Type MetadataEven though Ignite binary protocol only works with hash codes for type and field names to achieve better performance, Ignite provides metadata for all binary types which can be queried ar runtime via any of theIgniteBinary.type(Class)methods. Having metadata also allows for proper formatting ofBinaryObject.toString()method, even when binary objects are kept in binary format only, which may be necessary for audit reasons.
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description BinaryObjectclone()Copies this binary object.<T> Tdeserialize()Gets fully deserialized instance of binary object.<T> Tdeserialize(ClassLoader ldr)Gets fully deserialized instance of binary object.StringenumName()Get name for this enum object.intenumOrdinal()Get ordinal for this enum object.<F> Ffield(String fieldName)Gets field value.booleanhasField(String fieldName)Checks whether field exists in the object.intsize()Get the size of the objectBinaryObjectBuildertoBuilder()Creates a newBinaryObjectBuilderbased on this binary object.BinaryTypetype()Gets type information for this binary object.
 
- 
- 
- 
Method Detail- 
typeBinaryType type() throws BinaryObjectException Gets type information for this binary object.- Returns:
- Binary object type information.
- Throws:
- BinaryObjectException- In case of error.
 
 - 
field<F> F field(String fieldName) throws BinaryObjectException Gets field value.- Type Parameters:
- F- Type of the field value.
- Parameters:
- fieldName- Field name.
- Returns:
- Field value.
- Throws:
- BinaryObjectException- In case of any other error.
 
 - 
hasFieldboolean hasField(String fieldName) Checks whether field exists in the object.- Parameters:
- fieldName- Field name.
- Returns:
- Trueif field exists.
 
 - 
deserialize<T> T deserialize() throws BinaryObjectExceptionGets fully deserialized instance of binary object.- Type Parameters:
- T- Type of the deserialized object.
- Returns:
- Fully deserialized instance of binary object.
- Throws:
- BinaryInvalidTypeException- If class doesn't exist.
- BinaryObjectException- In case of any other error.
 
 - 
deserialize<T> T deserialize(ClassLoader ldr) throws BinaryObjectException Gets fully deserialized instance of binary object. Ifldrwas not specified, configured class loader will be usedIgniteConfiguration.getClassLoader().- Type Parameters:
- T- Type of the deserialized object.
- Parameters:
- ldr- Class loader.
- Returns:
- Fully deserialized instance of binary object.
- Throws:
- BinaryInvalidTypeException- If class doesn't exist.
- BinaryObjectException- In case of any other error.
 
 - 
cloneBinaryObject clone() throws CloneNotSupportedException Copies this binary object.- Returns:
- Copy of this binary object.
- Throws:
- CloneNotSupportedException
 
 - 
toBuilderBinaryObjectBuilder toBuilder() throws BinaryObjectException Creates a newBinaryObjectBuilderbased on this binary object. The following codeBinaryObjectBuilder builder = binaryObject.toBuilder(); is equivalent toBinaryObjectBuilder builder = ignite.binary().builder(binaryObject); - Returns:
- Binary object builder.
- Throws:
- BinaryObjectException- If builder cannot be created.
 
 - 
enumOrdinalint enumOrdinal() throws BinaryObjectExceptionGet ordinal for this enum object. UseBinaryType.isEnum()to check if object is of enum type.- Returns:
- Ordinal.
- Throws:
- BinaryObjectException- If object is not enum.
 
 - 
enumNameString enumName() throws BinaryObjectException Get name for this enum object. UseBinaryType.isEnum()to check if object is of enum type.- Returns:
- Name.
- Throws:
- BinaryObjectException- If object is not enum.
 
 - 
sizeint size() Get the size of the object- Returns:
- Size of the object
 
 
- 
 
-