data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.linkedin.dagli.util.function.ShortMethodReference11 Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of util-function Show documentation
Show all versions of util-function Show documentation
DAG-oriented machine learning framework for bug-resistant, readable, efficient, maintainable and trivially deployable models in Java and other JVM languages
// AUTOGENERATED CODE. DO NOT MODIFY DIRECTLY! Instead, please modify the util/function/MethodReference.ftl file.
// See the README in the module's src/template directory for details.
package com.linkedin.dagli.util.function;
import java.io.IOException;
import java.lang.invoke.LambdaMetafactory;
import java.lang.invoke.MethodHandle;
import java.lang.invoke.MethodType;
/**
* Represents a safely serializable method reference (assuming the JVM supports {@link MethodReference}, which is not
* guaranteed). If the JVM does not support {@link MethodReference}, an exception may be thrown when creating the
* method reference; fortunately, however, deserialization will not be affected: if you can serialize it, you'll be able
* to deserialize later on any JVM.
*/
class ShortMethodReference11 implements
ShortFunction11.Serializable {
private static final long serialVersionUID = 1;
// hash and equality distinguish between different types of MethodReferenceX classes even when the underlying method
// references are identical
private static final int CLASS_HASH = ShortMethodReference11.class.hashCode();
private final MethodReference _methodReference;
private transient ShortFunction11 _cachedFunction = null;
ShortMethodReference11(MethodReference mr) {
_methodReference = mr;
initCachedFunction();
}
/**
* Creates a new instance.
*
* The passed func parameter must be a method reference, such as Object::toString or String::length. A runtime
* exception will be thrown if func is a function object or an anonymous lambda (e.g. "a -> a + 5"). An exception
* may also be thrown if your JVM implementation does not support the library's internal method for retrieving
* information about the passed method reference.
*
* @param func a method reference lambda to wrap. If this function is not safely serializable, a runtime exception
* will be thrown.
*/
public ShortMethodReference11(Serializable func) {
if (func instanceof ShortMethodReference11) {
// multiple applications of this constructor are idempotent:
_methodReference = ((ShortMethodReference11) func)._methodReference;
} else {
// this line will thrown an exception if func is not a method reference:
_methodReference = new MethodReference(func);
}
initCachedFunction();
}
// deserialization hook to ensure _cachedFunction is always set
private void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException {
in.defaultReadObject();
initCachedFunction();
}
private void initCachedFunction() {
if (_cachedFunction == null) {
_cachedFunction = fromMethodReference();
}
}
private ShortFunction11 fromMethodReference() {
MethodHandle mh = _methodReference.getMethodHandle();
try {
MethodType type = mh.type().generic().changeReturnType(short.class);
return (ShortFunction11) LambdaMetafactory
.metafactory(_methodReference.getLookup(), "apply", MethodType.methodType(ShortFunction11.class), type, mh,
mh.type().wrap().changeReturnType(short.class)).getTarget().invokeExact();
} catch (Throwable e) {
throw new RuntimeException(e);
}
}
public short apply(A value1, B value2, C value3, D value4, E value5, F value6, G value7, H value8, I value9,
J value10, K value11) {
return _cachedFunction.apply(value1, value2, value3, value4, value5, value6, value7, value8, value9, value10,
value11);
}
@Override
public int hashCode() {
return CLASS_HASH + _methodReference.hashCode();
}
@Override
public boolean equals(Object obj) {
if (!(obj instanceof ShortMethodReference11)) {
return false;
}
return _methodReference.equals(((ShortMethodReference11) obj)._methodReference);
}
@Override
public String toString() {
return _methodReference.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy