--- jsr166/src/test/loops/RWMap.java 2009/10/29 23:09:08 1.5 +++ jsr166/src/test/loops/RWMap.java 2010/10/16 16:22:57 1.6 @@ -13,7 +13,6 @@ import java.util.concurrent.locks.*; * that places read-write locks around unsynchronized Maps. * Exists as a sample input for MapLoops test. */ - public class RWMap implements Map { private final Map m; private final ReentrantReadWriteLock rwl = new ReentrantReadWriteLock(); @@ -31,28 +30,39 @@ public class RWMap implements Map { public int size() { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.size();} finally { l.unlock(); } + l.lock(); + try { return m.size(); } + finally { l.unlock(); } } - public boolean isEmpty(){ + + public boolean isEmpty() { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.isEmpty();} finally { l.unlock(); } + l.lock(); + try { return m.isEmpty(); } + finally { l.unlock(); } } public Object get(Object key) { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.get(key);} finally { l.unlock(); } + l.lock(); + try { return m.get(key); } + finally { l.unlock(); } } public boolean containsKey(Object key) { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.containsKey(key);} finally { l.unlock(); } + l.lock(); + try { return m.containsKey(key); } + finally { l.unlock(); } } - public boolean containsValue(Object value){ + + public boolean containsValue(Object value) { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.containsValue(value);} finally { l.unlock(); } + l.lock(); + try { return m.containsValue(value); } + finally { l.unlock(); } } - public Set keySet() { // Not implemented return m.keySet(); } @@ -67,34 +77,51 @@ public class RWMap implements Map { public boolean equals(Object o) { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.equals(o);} finally { l.unlock(); } + l.lock(); + try { return m.equals(o); } + finally { l.unlock(); } } + public int hashCode() { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.hashCode();} finally { l.unlock(); } + l.lock(); + try { return m.hashCode(); } + finally { l.unlock(); } } + public String toString() { ReentrantReadWriteLock.ReadLock l = rwl.readLock(); - l.lock(); try {return m.toString();} finally { l.unlock(); } + l.lock(); + try { return m.toString(); } + finally { l.unlock(); } } - - public Object put(Object key, Object value) { ReentrantReadWriteLock.WriteLock l = rwl.writeLock(); - l.lock(); try {return m.put(key, value);} finally { l.unlock(); } + l.lock(); + try { return m.put(key, value); } + finally { l.unlock(); } } + public Object remove(Object key) { ReentrantReadWriteLock.WriteLock l = rwl.writeLock(); - l.lock(); try {return m.remove(key);} finally { l.unlock(); } + l.lock(); + try { return m.remove(key); } + finally { l.unlock(); } } + public void putAll(Map map) { ReentrantReadWriteLock.WriteLock l = rwl.writeLock(); - l.lock(); try {m.putAll(map);} finally { l.unlock(); } + l.lock(); + try { m.putAll(map); } + finally { l.unlock(); } } + public void clear() { ReentrantReadWriteLock.WriteLock l = rwl.writeLock(); - l.lock(); try {m.clear();} finally { l.unlock(); } + l.lock(); + try { m.clear(); } + finally { l.unlock(); } } }