001: /**********************************************************************
002: Copyright (c) 2004 Andy Jefferson and others. All rights reserved.
003: Licensed under the Apache License, Version 2.0 (the "License");
004: you may not use this file except in compliance with the License.
005: You may obtain a copy of the License at
006:
007: http://www.apache.org/licenses/LICENSE-2.0
008:
009: Unless required by applicable law or agreed to in writing, software
010: distributed under the License is distributed on an "AS IS" BASIS,
011: WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
012: See the License for the specific language governing permissions and
013: limitations under the License.
014:
015:
016: Contributors:
017: ...
018: **********************************************************************/package org.jpox.cache;
019:
020: import java.util.Collection;
021: import java.util.HashMap;
022: import java.util.Map;
023: import java.util.Set;
024:
025: /**
026: * Implementation of a Level 1 cache keeping hard (strong) references
027: * to the objects. This means that objects are not garbage collected,
028: * and have to be removed directly by calls to remove(). This differs
029: * from the WeakRefCache/SoftRefCache which do not guarantee to retain
030: * objects.
031: *
032: * @version $Revision: 1.3 $
033: */
034: public class HardRefCache implements Level1Cache {
035: private Map hardCache = new HashMap();
036:
037: /**
038: * Default constructor (required)
039: */
040: public HardRefCache() {
041: //default constructor
042: }
043:
044: public Object put(Object key, Object value) {
045: return hardCache.put(key, value);
046: }
047:
048: public Object get(Object key) {
049: return hardCache.get(key);
050: }
051:
052: public boolean containsKey(Object key) {
053: return hardCache.containsKey(key);
054: }
055:
056: public Object remove(Object key) {
057: return hardCache.remove(key);
058: }
059:
060: public void clear() {
061: hardCache.clear();
062: }
063:
064: /* (non-Javadoc)
065: * @see java.util.Map#containsValue(java.lang.Object)
066: */
067: public boolean containsValue(Object value) {
068: return hardCache.containsValue(value);
069: }
070:
071: /* (non-Javadoc)
072: * @see java.util.Map#entrySet()
073: */
074: public Set entrySet() {
075: return hardCache.entrySet();
076: }
077:
078: /* (non-Javadoc)
079: * @see java.util.Map#isEmpty()
080: */
081: public boolean isEmpty() {
082: return hardCache.isEmpty();
083: }
084:
085: /* (non-Javadoc)
086: * @see java.util.Map#keySet()
087: */
088: public Set keySet() {
089: return hardCache.keySet();
090: }
091:
092: /* (non-Javadoc)
093: * @see java.util.Map#putAll(java.util.Map)
094: */
095: public void putAll(Map t) {
096: hardCache.putAll(t);
097: }
098:
099: /* (non-Javadoc)
100: * @see java.util.Map#size()
101: */
102: public int size() {
103: return hardCache.size();
104: }
105:
106: /* (non-Javadoc)
107: * @see java.util.Map#values()
108: */
109: public Collection values() {
110: return hardCache.values();
111: }
112: }
|