Class ArrayType
java.lang.Object
com.fasterxml.jackson.core.type.ResolvedType
com.fasterxml.jackson.databind.JavaType
com.fasterxml.jackson.databind.type.TypeBase
com.fasterxml.jackson.databind.type.ArrayType
- All Implemented Interfaces:
JsonSerializable,Serializable,Type
Array types represent Java arrays, both primitive and object valued.
Further, Object-valued arrays can have element type of any other
legal
JavaType.- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface com.fasterxml.jackson.databind.JsonSerializable
JsonSerializable.Base -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final JavaTypeType of elements in the array.protected final ObjectWe will also keep track of shareable instance of empty array, since it usually needs to be constructed any way; and because it is essentially immutable and thus can be shared.Fields inherited from class com.fasterxml.jackson.databind.type.TypeBase
_bindings, _superClass, _superInterfacesFields inherited from class com.fasterxml.jackson.databind.JavaType
_asStatic, _class, _hash, _typeHandler, _valueHandler -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic ArrayTypeconstruct(JavaType componentType, TypeBindings bindings) static ArrayTypeconstruct(JavaType componentType, TypeBindings bindings, Object valueHandler, Object typeHandler) booleanMethod for accessing content type of this type, if type has such a thing: simple types do not, structured types do (like arrays, Collections and Maps)Internal accessor that should not be used by any code outside of jackson-databind: only used internally by databind.Internal accessor that should not be used by any code outside of jackson-databind: only used internally by databind.Object[]Method for accessing signature without generic type information, in form compatible with all versions of JVM, and specifically used for type descriptions when generating byte code.booleanMethod that can be used to find out if the type directly declares generic parameters (for its direct super-class and/or super-interfaces).booleanHelper method that checks whether this type, or its (optional) key or content type hasJavaType.getValueHandler()orJavaType.getTypeHandler(); that is, are there any non-standard handlers associated with this type object.booleanFor some odd reason, modifiers for array classes would claim they are abstract types.booleanbooleanFor some odd reason, modifiers for array classes would claim they are abstract types.booleanrefine(Class<?> contentClass, TypeBindings bindings, JavaType superClass, JavaType[] superInterfaces) Mutant factory method that will try to create and return a sub-type instance for known parameterized types; for other types will return `null` to indicate that no just refinement makes necessary sense, without trying to detect special status through implemented interfaces.toString()withContentType(JavaType contentType) Mutant factory method that may be called on structured types that have a so-called content type (element of arrays, value type of Maps, referenced type of referential types), and will construct a new instance that is identical to this instance, except that it has specified content type, instead of current one.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Method that can be called to get a type instance that indicates that values of the type should be handled using "static typing" for purposes of serialization (as opposed to "dynamic" aka runtime typing): meaning that no runtime information is needed for determining serializers to use.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Methods inherited from class com.fasterxml.jackson.databind.type.TypeBase
_bogusSuperClass, _classSignature, _hasNTypeParameters, buildCanonicalName, containedType, containedTypeCount, containedTypeName, findSuperType, findTypeParameters, getBindings, getInterfaces, getSuperClass, serialize, serializeWithType, toCanonicalMethods inherited from class com.fasterxml.jackson.databind.JavaType
_narrow, containedTypeOrUnknown, forcedNarrowBy, getErasedSignature, getGenericSignature, getKeyType, getParameterSource, getRawClass, getReferencedType, getTypeHandler, getValueHandler, hasContentType, hashCode, hasRawClass, hasValueHandler, isCollectionLikeType, isEnumImplType, isEnumType, isFinal, isInterface, isIterationType, isJavaLangObject, isMapLikeType, isPrimitive, isRecordType, isThrowable, isTypeOrSubTypeOf, isTypeOrSuperTypeOf, useStaticType, withHandlersFromMethods inherited from class com.fasterxml.jackson.core.type.ResolvedType
isReferenceTypeMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.lang.reflect.Type
getTypeName
-
Field Details
-
_componentType
Type of elements in the array. -
_emptyArray
We will also keep track of shareable instance of empty array, since it usually needs to be constructed any way; and because it is essentially immutable and thus can be shared.
-
-
Constructor Details
-
ArrayType
protected ArrayType(JavaType componentType, TypeBindings bindings, Object emptyInstance, Object valueHandler, Object typeHandler, boolean asStatic)
-
-
Method Details
-
construct
-
construct
public static ArrayType construct(JavaType componentType, TypeBindings bindings, Object valueHandler, Object typeHandler) -
withContentType
Description copied from class:JavaTypeMutant factory method that may be called on structured types that have a so-called content type (element of arrays, value type of Maps, referenced type of referential types), and will construct a new instance that is identical to this instance, except that it has specified content type, instead of current one. If content type is already set to given type,thisis returned. If type does not have a content type (which is the case withSimpleType),IllegalArgumentExceptionwill be thrown.- Specified by:
withContentTypein classJavaType- Returns:
- Newly created type instance
-
withTypeHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.This mutant factory method will construct a new instance that is identical to this instance, except that it will have specified type handler assigned.
- Specified by:
withTypeHandlerin classJavaType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withContentTypeHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.This mutant factory method will construct a new instance that is identical to this instance, except that it will have specified content type (element type for arrays, value type for Maps and so forth) handler assigned.
- Specified by:
withContentTypeHandlerin classJavaType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withValueHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.This mutant factory method will construct a new instance that is identical to this instance, except that it will have specified value handler assigned.
- Specified by:
withValueHandlerin classJavaType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withContentValueHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.Mutant factory method that will construct a new instance that is identical to this instance, except that it will have specified content value handler assigned.
- Specified by:
withContentValueHandlerin classJavaType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withStaticTyping
Description copied from class:JavaTypeMethod that can be called to get a type instance that indicates that values of the type should be handled using "static typing" for purposes of serialization (as opposed to "dynamic" aka runtime typing): meaning that no runtime information is needed for determining serializers to use. The main use case is to allow forcing of specific root value serialization type, and specifically in resolving serializers for contained types (element types for arrays, Collections and Maps).- Specified by:
withStaticTypingin classJavaType
-
refine
public JavaType refine(Class<?> contentClass, TypeBindings bindings, JavaType superClass, JavaType[] superInterfaces) Description copied from class:JavaTypeMutant factory method that will try to create and return a sub-type instance for known parameterized types; for other types will return `null` to indicate that no just refinement makes necessary sense, without trying to detect special status through implemented interfaces. -
isArrayType
public boolean isArrayType()- Overrides:
isArrayTypein classJavaType
-
isAbstract
public boolean isAbstract()For some odd reason, modifiers for array classes would claim they are abstract types. Not so, at least for our purposes.- Overrides:
isAbstractin classJavaType
-
isConcrete
public boolean isConcrete()For some odd reason, modifiers for array classes would claim they are abstract types. Not so, at least for our purposes.- Overrides:
isConcretein classJavaType
-
hasGenericTypes
public boolean hasGenericTypes()Description copied from class:ResolvedTypeMethod that can be used to find out if the type directly declares generic parameters (for its direct super-class and/or super-interfaces).- Overrides:
hasGenericTypesin classJavaType- Returns:
Trueif this type has generic type parameters,falseif not
-
isContainerType
public boolean isContainerType()- Specified by:
isContainerTypein classJavaType- Returns:
- True if type represented is a container type; this includes array, Map and Collection types.
-
getContentType
Description copied from class:ResolvedTypeMethod for accessing content type of this type, if type has such a thing: simple types do not, structured types do (like arrays, Collections and Maps)- Overrides:
getContentTypein classJavaType- Returns:
- Content type of this type, if any;
nullif none
-
getContentValueHandler
Description copied from class:JavaTypeInternal accessor that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.- Overrides:
getContentValueHandlerin classJavaType- Returns:
- Content value handler associated with this type, if any.
-
getContentTypeHandler
Description copied from class:JavaTypeInternal accessor that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.- Overrides:
getContentTypeHandlerin classJavaType- Returns:
- Content type handler associated with this type, if any.
-
hasHandlers
public boolean hasHandlers()Description copied from class:JavaTypeHelper method that checks whether this type, or its (optional) key or content type hasJavaType.getValueHandler()orJavaType.getTypeHandler(); that is, are there any non-standard handlers associated with this type object.- Overrides:
hasHandlersin classJavaType
-
getGenericSignature
- Specified by:
getGenericSignaturein classTypeBase- Parameters:
sb- StringBuilder to append signature to- Returns:
- StringBuilder that was passed in; returned to allow call chaining
-
getErasedSignature
Description copied from class:JavaTypeMethod for accessing signature without generic type information, in form compatible with all versions of JVM, and specifically used for type descriptions when generating byte code.- Specified by:
getErasedSignaturein classTypeBase- Parameters:
sb- StringBuilder to append signature to- Returns:
- StringBuilder that was passed in; returned to allow call chaining
-
getEmptyArray
- Since:
- 2.12
-
toString
-
equals
-