org.zkoss.util
Class MultiCache

java.lang.Object
  extended by org.zkoss.util.MultiCache
All Implemented Interfaces:
java.io.Serializable, java.lang.Cloneable, Cache

public class MultiCache
extends java.lang.Object
implements Cache, java.io.Serializable, java.lang.Cloneable

A CacheMap-based cache. It creates multiple instances of CacheMap, called the internal caches, and then distributes the access across them. Thus, the performance is porportional to the number of internal caches.

Thread safe.

Since:
3.0.0
Author:
tomyeh
See Also:
Serialized Form

Field Summary
 
Fields inherited from interface org.zkoss.util.Cache
DEFAULT_LIFETIME, DEFAULT_MAX_SIZE
 
Constructor Summary
MultiCache()
          Constructs a multi cache with 17 inital caches.
MultiCache(int nCache)
          Constructs a multi cache with the specified number of internal caches.
MultiCache(int nCache, int initSize)
          Deprecated. As of release 5.0.0, replaced with MultiCache(int)
MultiCache(int nCache, int maxSize, int lifetime)
          Constucts a multi cache with the specified number of internal caches, the max size and the lifetime.
 
Method Summary
 void clear()
          Clears all objects being cached.
 java.lang.Object clone()
           
 boolean containsKey(java.lang.Object key)
          Returns whether the specified key is stored.
 java.lang.Object get(java.lang.Object key)
          Returns the object of the specified key, or null if not found.
 int getLifetime()
          Returns the minimal lifetime, unit=milliseconds.
 int getMaxSize()
          Returns the maximal allowed size.
 java.lang.Object put(java.lang.Object key, java.lang.Object value)
          Stores an object to the cache.
 java.lang.Object remove(java.lang.Object key)
          Removes an object from the cache.
 void setLifetime(int lifetime)
          Sets the minimal lifetime.
 void setMaxSize(int maxsize)
          Sets the maximal allowed size.
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

MultiCache

public MultiCache()
Constructs a multi cache with 17 inital caches.


MultiCache

public MultiCache(int nCache,
                  int maxSize,
                  int lifetime)
Constucts a multi cache with the specified number of internal caches, the max size and the lifetime.

Parameters:
nCache - the postive number of the internal caches. The large the number the fast the performance.
maxSize - the maximal allowed size of each cache

MultiCache

public MultiCache(int nCache)
Constructs a multi cache with the specified number of internal caches.

The default lifetime is Cache.DEFAULT_LIFETIME, and the default maximal allowed size of each cache is (Cache.DEFAULT_MAX_SIZE / 10).

Parameters:
nCache - the postive number of the internal caches. The large the number the fast the performance.

MultiCache

public MultiCache(int nCache,
                  int initSize)
Deprecated. As of release 5.0.0, replaced with MultiCache(int)

Method Detail

containsKey

public boolean containsKey(java.lang.Object key)
Description copied from interface: Cache
Returns whether the specified key is stored.

Specified by:
containsKey in interface Cache

get

public java.lang.Object get(java.lang.Object key)
Description copied from interface: Cache
Returns the object of the specified key, or null if not found.

Specified by:
get in interface Cache

put

public java.lang.Object put(java.lang.Object key,
                            java.lang.Object value)
Description copied from interface: Cache
Stores an object to the cache.

Specified by:
put in interface Cache
Returns:
the previous value of the same, or null if no such value

remove

public java.lang.Object remove(java.lang.Object key)
Description copied from interface: Cache
Removes an object from the cache.

Specified by:
remove in interface Cache
Returns:
the object if found.

clear

public void clear()
Description copied from interface: Cache
Clears all objects being cached.

Specified by:
clear in interface Cache

getLifetime

public int getLifetime()
Description copied from interface: Cache
Returns the minimal lifetime, unit=milliseconds. An mapping won't be removed by GC unless the minimal lifetime or the maximal allowed size exceeds.

Specified by:
getLifetime in interface Cache
See Also:
Cache.getMaxSize()

setLifetime

public void setLifetime(int lifetime)
Description copied from interface: Cache
Sets the minimal lifetime. Default: Cache.DEFAULT_LIFETIME.

Specified by:
setLifetime in interface Cache
Parameters:
lifetime - the lifetime, unit=milliseconds; if non-posive, they will be removed immediately.
See Also:
Cache.getLifetime()

getMaxSize

public int getMaxSize()
Description copied from interface: Cache
Returns the maximal allowed size. Defalut: Cache.DEFAULT_MAX_SIZE. An mapping won't be removed by GC unless the minimal lifetime or the maximal allowed size exceeds.

Specified by:
getMaxSize in interface Cache
See Also:
Cache.getLifetime()

setMaxSize

public void setMaxSize(int maxsize)
Description copied from interface: Cache
Sets the maximal allowed size.

Specified by:
setMaxSize in interface Cache
See Also:
Cache.getMaxSize()

clone

public java.lang.Object clone()
Overrides:
clone in class java.lang.Object


Copyright © 2005-2009 Potix Corporation. All Rights Reserved. SourceForge.net Logo