Class MethodReference
Null-safe Invocation
Null-safe invocation is supported via the '?.' operator. For example,
'counter?.incrementBy(1)' will evaluate to null if counter
is null and will otherwise evaluate to the value returned from the
invocation of counter.incrementBy(1). As of Spring Framework 7.0,
null-safe invocation also applies when invoking a method on an Optional
target. For example, if counter is of type Optional<Counter>,
the expression 'counter?.incrementBy(1)' will evaluate to null
if counter is null or empty and will
otherwise evaluate the value returned from the invocation of
counter.get().incrementBy(1).
- Since:
- 3.0
- Author:
- Andy Clement, Juergen Hoeller, Sam Brannen
-
Field Summary
Fields inherited from class SpelNodeImpl
children, exitTypeDescriptorFields inherited from interface Opcodes
AALOAD, AASTORE, ACC_ABSTRACT, ACC_ANNOTATION, ACC_BRIDGE, ACC_DEPRECATED, ACC_ENUM, ACC_FINAL, ACC_INTERFACE, ACC_MANDATED, ACC_MODULE, ACC_NATIVE, ACC_OPEN, ACC_PRIVATE, ACC_PROTECTED, ACC_PUBLIC, ACC_RECORD, ACC_STATIC, ACC_STATIC_PHASE, ACC_STRICT, ACC_SUPER, ACC_SYNCHRONIZED, ACC_SYNTHETIC, ACC_TRANSIENT, ACC_TRANSITIVE, ACC_VARARGS, ACC_VOLATILE, ACONST_NULL, ALOAD, ANEWARRAY, ARETURN, ARRAYLENGTH, ASM10_EXPERIMENTAL, ASM4, ASM5, ASM6, ASM7, ASM8, ASM9, ASTORE, ATHROW, BALOAD, BASTORE, BIPUSH, CALOAD, CASTORE, CHECKCAST, D2F, D2I, D2L, DADD, DALOAD, DASTORE, DCMPG, DCMPL, DCONST_0, DCONST_1, DDIV, DLOAD, DMUL, DNEG, DOUBLE, DREM, DRETURN, DSTORE, DSUB, DUP, DUP_X1, DUP_X2, DUP2, DUP2_X1, DUP2_X2, F_APPEND, F_CHOP, F_FULL, F_NEW, F_SAME, F_SAME1, F2D, F2I, F2L, FADD, FALOAD, FASTORE, FCMPG, FCMPL, FCONST_0, FCONST_1, FCONST_2, FDIV, FLOAD, FLOAT, FMUL, FNEG, FREM, FRETURN, FSTORE, FSUB, GETFIELD, GETSTATIC, GOTO, H_GETFIELD, H_GETSTATIC, H_INVOKEINTERFACE, H_INVOKESPECIAL, H_INVOKESTATIC, H_INVOKEVIRTUAL, H_NEWINVOKESPECIAL, H_PUTFIELD, H_PUTSTATIC, I2B, I2C, I2D, I2F, I2L, I2S, IADD, IALOAD, IAND, IASTORE, ICONST_0, ICONST_1, ICONST_2, ICONST_3, ICONST_4, ICONST_5, ICONST_M1, IDIV, IF_ACMPEQ, IF_ACMPNE, IF_ICMPEQ, IF_ICMPGE, IF_ICMPGT, IF_ICMPLE, IF_ICMPLT, IF_ICMPNE, IFEQ, IFGE, IFGT, IFLE, IFLT, IFNE, IFNONNULL, IFNULL, IINC, ILOAD, IMUL, INEG, INSTANCEOF, INTEGER, INVOKEDYNAMIC, INVOKEINTERFACE, INVOKESPECIAL, INVOKESTATIC, INVOKEVIRTUAL, IOR, IREM, IRETURN, ISHL, ISHR, ISTORE, ISUB, IUSHR, IXOR, JSR, L2D, L2F, L2I, LADD, LALOAD, LAND, LASTORE, LCMP, LCONST_0, LCONST_1, LDC, LDIV, LLOAD, LMUL, LNEG, LONG, LOOKUPSWITCH, LOR, LREM, LRETURN, LSHL, LSHR, LSTORE, LSUB, LUSHR, LXOR, MONITORENTER, MONITOREXIT, MULTIANEWARRAY, NEW, NEWARRAY, NOP, NULL, POP, POP2, PUTFIELD, PUTSTATIC, RET, RETURN, SALOAD, SASTORE, SIPUSH, SOURCE_DEPRECATED, SOURCE_MASK, SWAP, T_BOOLEAN, T_BYTE, T_CHAR, T_DOUBLE, T_FLOAT, T_INT, T_LONG, T_SHORT, TABLESWITCH, TOP, UNINITIALIZED_THIS, V_PREVIEW, V1_1, V1_2, V1_3, V1_4, V1_5, V1_6, V1_7, V1_8, V10, V11, V12, V13, V14, V15, V16, V17, V18, V19, V20, V21, V22, V23, V24, V25, V9 -
Constructor Summary
ConstructorsConstructorDescriptionMethodReference(boolean nullSafe, String methodName, int startPos, int endPos, SpelNodeImpl... arguments) -
Method Summary
Modifier and TypeMethodDescriptionvoidgenerateCode(MethodVisitor mv, CodeFlow cf) Generate the bytecode for this node into the suppliedMethodVisitor.final StringgetName()Get the name of the referenced method.getValueInternal(ExpressionState state) protected ValueRefgetValueRef(ExpressionState state) booleanA method reference is compilable if it has been resolved to a reflectively accessible method and the child nodes (arguments to the method) are also compilable.final booleanDoes this node represent a null-safe method reference?Return the string form of this AST node.Methods inherited from class SpelNodeImpl
generateCodeForArgument, generateCodeForArguments, generateCodeForArguments, getChild, getChildCount, getEndPosition, getExitDescriptor, getObjectClass, getStartPosition, getTypedValue, getValue, getValue, isWritable, nextChildIs, setValue, setValueInternal
-
Constructor Details
-
MethodReference
public MethodReference(boolean nullSafe, String methodName, int startPos, int endPos, SpelNodeImpl... arguments)
-
-
Method Details
-
isNullSafe
public final boolean isNullSafe()Does this node represent a null-safe method reference?- Overrides:
isNullSafein classSpelNodeImpl- Returns:
trueif this node is the target of a null-safe operation- Since:
- 6.0.13
-
getName
Get the name of the referenced method. -
getValueRef
- Overrides:
getValueRefin classSpelNodeImpl- Throws:
EvaluationException
-
getValueInternal
- Specified by:
getValueInternalin classSpelNodeImpl- Throws:
EvaluationException
-
toStringAST
-
isCompilable
public boolean isCompilable()A method reference is compilable if it has been resolved to a reflectively accessible method and the child nodes (arguments to the method) are also compilable.- Returns:
trueif this node can be compiled to bytecode- See Also:
-
generateCode
Description copied from interface:SpelNodeGenerate the bytecode for this node into the suppliedMethodVisitor.Context information about the current expression being compiled is available in the supplied
CodeFlowobject — for example, information about the type of the object currently on the stack.This method will not be invoked unless
SpelNode.isCompilable()returnstrue.The default implementation throws an
IllegalStateExceptionsinceSpelNode.isCompilable()returnsfalseby default.If you override this method, you must also override
SpelNode.isCompilable().- Parameters:
mv- the ASMMethodVisitorinto which code should be generatedcf- a context object with information about what is on the stack- See Also:
-