com.googlecode.ehcache.annotations.key.ListCacheKeyGenerator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ehcache-spring-annotations Show documentation
Show all versions of ehcache-spring-annotations Show documentation
Provides a simple model for integrating Ehcache in a Spring project via annotations.
/**
* Copyright 2010 Nicholas Blair, Eric Dalquist
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.googlecode.ehcache.annotations.key;
import java.io.Serializable;
import java.lang.reflect.Array;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Collections;
/**
* This key generator is a good option when you want to be 100% sure that two sets of method invocation arguments
* are the same. The original arguments are completely preserved and used in every hashCode and equals call made
* on the key.
*
* The caveats with this approach are:
*
* -
* All method arguments must be completely {@link Serializable}. A {@link ClassCastException} will be thrown if
* any argument does not implmenent {@link Serializable}.
*
* -
* The more complex implementation of hashCode and equals on each argument the more expensive this key is to
* compare during cache access operations.
*
*
*
* Builds a List out of the method arguments. If any of the arguments are arrays they are converted to lists and this
* check is done recursively on every visible array element. All non-array objects should have a good equals and hashCode
* implementation as the List that is returned will delegate to the argument and array member hashCode and equals
* implementations.
*
* If includeMethod is set to true {@link Method#getDeclaringClass()}, {@link Method#getName()},
* {@link Method#getReturnType()}, and {@link Method#getParameterTypes()} will be included in the generated
* key. includeMethod defaults to true.
*
* @author Eric Dalquist
* @version $Revision: 138 $
*/
public class ListCacheKeyGenerator extends AbstractCacheKeyGenerator> {
public static final String DEFAULT_BEAN_NAME = "com.googlecode.ehcache.annotations.key.ListCacheKeyGenerator.DEFAULT_BEAN_NAME";
public ListCacheKeyGenerator() {
}
public ListCacheKeyGenerator(boolean includeMethod, boolean includeParameterTypes) {
super(includeMethod, includeParameterTypes);
}
@Override
protected ReadOnlyList generateKey(Object... data) {
final ArrayList keyList = new ArrayList(data.length);
for (final Object arg : data) {
keyList.add(this.arrayCheck((Serializable)arg));
}
return new ReadOnlyList(keyList);
}
protected Serializable arrayCheck(Serializable object) {
if (object == null || !register(object)) {
//Return null in place of the actual hash code in the case of a circular reference
return null;
}
try {
final Class extends Object> c = object.getClass();
if (!c.isArray()) {
return object;
}
final int length = Array.getLength(object);
final ArrayList