Class ObjectMethods
java.lang.Object
java.lang.runtime.ObjectMethods
Bootstrap methods for state-driven implementations of core methods,
including
Object.equals(Object), Object.hashCode(), and
Object.toString(). These methods may be used, for example, by
Java compiler implementations to implement the bodies of Object
methods for record classes.- Since:
- 16
-
Method Summary
Modifier and TypeMethodDescriptionstatic Objectbootstrap(MethodHandles.Lookup lookup, String methodName, TypeDescriptor type, Class<?> recordClass, String names, MethodHandle... getters) Bootstrap method to generate theObject.equals(Object),Object.hashCode(), andObject.toString()methods, based on a description of the component names and accessor methods, for eitherinvokedynamiccall sites or dynamic constant pool entries.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()Creates and returns a copy of this object.booleanIndicates whether some other object is "equal to" this one.protected voidfinalize()Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class<?> getClass()Returns the runtime class of thisObject.inthashCode()Returns a hash code value for this object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.toString()Returns a string representation of the object.final voidwait()Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final voidwait(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final voidwait(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Method Details
-
bootstrap
public static Object bootstrap(MethodHandles.Lookup lookup, String methodName, TypeDescriptor type, Class<?> recordClass, String names, MethodHandle... getters) throws Throwable Bootstrap method to generate theObject.equals(Object),Object.hashCode(), andObject.toString()methods, based on a description of the component names and accessor methods, for eitherinvokedynamiccall sites or dynamic constant pool entries. For more detail on the semantics of the generated methods see the specification ofRecord.equals(Object),Record.hashCode()andRecord.toString().- Parameters:
lookup- Every bootstrap method is expected to have alookupwhich usually represents a lookup context with the accessibility privileges of the caller. This is becauseinvokedynamiccall sites always provide alookupto the corresponding bootstrap method, but this method just ignores thelookupparametermethodName- the name of the method to generate, which must be one of"equals","hashCode", or"toString"type- aMethodTypecorresponding the descriptor type for the method, which must correspond to the descriptor for the correspondingObjectmethod, if linking aninvokedynamiccall site, or the constantMethodHandle.class, if linking a dynamic constantrecordClass- the record class hosting the record componentsnames- the list of component names, joined into a string separated by ";", or the empty string if there are no components. This parameter is ignored if themethodNameparameter is"equals"or"hashCode"getters- method handles for the accessor methods for the components- Returns:
- a call site if invoked by indy, or a method handle if invoked by a condy
- Throws:
IllegalArgumentException- if the bootstrap arguments are invalid or inconsistentNullPointerException- if any argument isnullor if any element in thegettersarray isnullThrowable- if any exception is thrown during call site construction
-