public final class SerializedLambda extends Objectimplements Serializable
Implementors of serializable lambdas, such as compilers or language runtime libraries, are expected to ensure that instances deserialize properly. One means to do so is to ensure that the writeReplace method returns an instance of SerializedLambda, rather than allowing default serialization to proceed.
SerializedLambda has a readResolve method that looks for a (possibly private) static method called $deserializeLambda$(SerializedLambda) in the capturing class, invokes that with itself as the first argument, and returns the result. Lambda classes implementing $deserializeLambda$ are responsible for validating that the properties of the SerializedLambda are consistent with a lambda actually captured by that class.
LambdaMetafactory,
Serialized Form
| Constructor and Description |
|---|
SerializedLambda(Class
Create a
SerializedLambda from the low-level information present at the lambda factory site.
|
| Modifier and Type | Method and Description |
|---|---|
Object |
getCapturedArg(int i)
Get a dynamic argument to the lambda capture site.
|
int |
getCapturedArgCount()
Get the count of dynamic arguments to the lambda capture site.
|
String |
getCapturingClass()
Get the name of the class that captured this lambda.
|
String |
getFunctionalInterfaceClass()
Get the name of the invoked type to which this lambda has been converted
|
String |
getFunctionalInterfaceMethodName()
Get the name of the primary method for the functional interface to which this lambda has been converted.
|
String |
getFunctionalInterfaceMethodSignature()
Get the signature of the primary method for the functional interface to which this lambda has been converted.
|
String |
getImplClass()
Get the name of the class containing the implementation method.
|
int |
getImplMethodKind()
Get the method handle kind (see
MethodHandleInfo) of the implementation method.
|
String |
getImplMethodName()
Get the name of the implementation method.
|
String |
getImplMethodSignature()
Get the signature of the implementation method.
|
String |
getInstantiatedMethodType()
Get the signature of the primary functional interface method after type variables are substituted with their instantiation from the capture site.
|
String |
toString()
Returns a string representation of the object.
|
public SerializedLambda(Class<?> capturingClass, String functionalInterfaceClass, String functionalInterfaceMethodName, String functionalInterfaceMethodSignature, int implMethodKind, String implClass, String implMethodName, String implMethodSignature, String instantiatedMethodType, Object [] capturedArgs)
SerializedLambda from the low-level information present at the lambda factory site.
capturingClass - The class in which the lambda expression appears
functionalInterfaceClass - Name, in slash-delimited form, of static type of the returned lambda object
functionalInterfaceMethodName - Name of the functional interface method for the present at the lambda factory site
functionalInterfaceMethodSignature - Signature of the functional interface method present at the lambda factory site
implMethodKind - Method handle kind for the implementation method
implClass - Name, in slash-delimited form, for the class holding the implementation method
implMethodName - Name of the implementation method
implMethodSignature - Signature of the implementation method
instantiatedMethodType - The signature of the primary functional interface method after type variables are substituted with their instantiation from the capture site
capturedArgs - The dynamic arguments to the lambda factory site, which represent variables captured by the lambda
public StringgetCapturingClass()
public StringgetFunctionalInterfaceClass()
public StringgetFunctionalInterfaceMethodName()
public StringgetFunctionalInterfaceMethodSignature()
public StringgetImplClass()
public StringgetImplMethodName()
public StringgetImplMethodSignature()
public int getImplMethodKind()
MethodHandleInfo) of the implementation method.
public final StringgetInstantiatedMethodType()
public int getCapturedArgCount()
public ObjectgetCapturedArg(int i)
i - the argument to capture
public StringtoString()
Object
toString method returns a string that "textually represents" this object. The result should be a concise but informative representation that is easy for a person to read. It is recommended that all subclasses override this method.
The toString method for class Object returns a string consisting of the name of the class of which the object is an instance, the at-sign character `@', and the unsigned hexadecimal representation of the hash code of the object. In other words, this method returns a string equal to the value of:
getClass().getName() + '@' + Integer.toHexString(hashCode())