HHH-16091 Optimize also AbstractStandardBasicType#compare and #fromString
This commit is contained in:
parent
12c7252c59
commit
2d7774b9ab
|
@ -12,6 +12,7 @@ import java.sql.PreparedStatement;
|
|||
import java.sql.SQLException;
|
||||
import java.sql.Types;
|
||||
import java.time.ZonedDateTime;
|
||||
import java.util.Comparator;
|
||||
import java.util.Map;
|
||||
|
||||
import org.hibernate.Hibernate;
|
||||
|
@ -51,6 +52,7 @@ public abstract class AbstractStandardBasicType<T>
|
|||
private final AbstractClassJavaType<T> javaTypeAsAbstractClassJavaType;
|
||||
private final Class javaTypeClass;
|
||||
private final MutabilityPlan<T> mutabilityPlan;
|
||||
private final Comparator<T> javatypeComparator;
|
||||
|
||||
public AbstractStandardBasicType(JdbcType jdbcType, JavaType<T> javaType) {
|
||||
this.jdbcType = jdbcType;
|
||||
|
@ -64,6 +66,7 @@ public abstract class AbstractStandardBasicType<T>
|
|||
//A very simple dispatch optimisation, make these a constant:
|
||||
this.javaTypeClass = javaType.getJavaTypeClass();
|
||||
this.mutabilityPlan = javaType.getMutabilityPlan();
|
||||
this.javatypeComparator = javaType.getComparator();
|
||||
//This is a dispatch optimisation to avoid megamorphic invocations on the most common type:
|
||||
if ( javaType instanceof AbstractClassJavaType ) {
|
||||
this.javaTypeAsAbstractClassJavaType = (AbstractClassJavaType) javaType;
|
||||
|
@ -94,8 +97,14 @@ public abstract class AbstractStandardBasicType<T>
|
|||
}
|
||||
|
||||
public T fromString(CharSequence string) {
|
||||
final AbstractClassJavaType<T> type = this.javaTypeAsAbstractClassJavaType;
|
||||
if ( type != null ) {
|
||||
return type.fromString( string );
|
||||
}
|
||||
else {
|
||||
return javaType.fromString( string );
|
||||
}
|
||||
}
|
||||
|
||||
protected MutabilityPlan<T> getMutabilityPlan() {
|
||||
return this.mutabilityPlan;
|
||||
|
@ -219,7 +228,7 @@ public abstract class AbstractStandardBasicType<T>
|
|||
@Override
|
||||
@SuppressWarnings("unchecked")
|
||||
public final int compare(Object x, Object y) {
|
||||
return javaType.getComparator().compare( (T) x, (T) y );
|
||||
return this.javatypeComparator.compare( (T) x, (T) y );
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
Loading…
Reference in New Issue