/* * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or (at your option) any later * version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ package com.l2jserver.gameserver.util; import java.util.Collection; import java.util.Map; import java.util.Set; import com.l2jserver.util.L2FastMap; import com.l2jserver.util.L2FastMap.I2ForEach; import com.l2jserver.util.L2FastMap.I2ForEachKey; import com.l2jserver.util.L2FastMap.I2ForEachValue; /** * Fully synchronized version of L2FastMap class.
* In addition it`s provide ForEach methods and interfaces that can be used for iterating collection without using iterators.
* As addition its provide full lock on entire class if needed
* WARNING!!! methods: keySet(), values() and entrySet() are removed!
* @author Julian Version: 1.0.0 <2008-02-07> - Original release * @author Julian Varsion: 1.0.1 <2008-06-17> - Changed underlying map to L2FastMap * @param * @param */ public class L2SyncMap implements Map { private final L2FastMap _map = new L2FastMap(); @Override public synchronized V put(K key, V value) { return _map.put(key, value); } @Override public synchronized V get(Object key) { return _map.get(key); } @Override public synchronized V remove(Object key) { return _map.remove(key); } @Override public synchronized boolean containsKey(Object key) { return _map.containsKey(key); } @Override public synchronized int size() { return _map.size(); } @Override public synchronized boolean isEmpty() { return _map.isEmpty(); } @Override public synchronized void clear() { _map.clear(); } /** * This method use specific locking strategy: map which have lowest hashCode() will be locked first * @see java.util.Map#putAll(java.util.Map) */ @Override public void putAll(Map map) { if ((map == null) || (this == map)) { return; } if (this.hashCode() <= map.hashCode()) { synchronized (this) { synchronized (map) { _map.putAll(map); } } } else { synchronized (map) { synchronized (this) { _map.putAll(map); } } } } @Override public synchronized boolean containsValue(Object value) { return _map.containsValue(value); } @Override public synchronized boolean equals(Object o) { return _map.equals(o); } @Override public synchronized int hashCode() { return _map.hashCode(); } @Override public synchronized String toString() { return _map.toString(); } /** * Public method that iterate entire collection.
*
* @param func - a class method that must be executed on every element of collection.
* @return - returns true if entire collection is iterated, false if it`s been interrupted by check method (I2ForEach.forEach())
*/ public synchronized final boolean ForEach(I2ForEach func) { return _map.ForEach(func); } public synchronized final boolean ForEachValue(I2ForEachValue func) { return _map.ForEachValue(func); } public synchronized final boolean ForEachKey(I2ForEachKey func) { return _map.ForEachKey(func); } /** * Unsupported operation!!! * @deprecated * @throws UnsupportedOperationException * @see java.util.Map#values() */ @Override @Deprecated public Collection values() { throw new UnsupportedOperationException(); } /** * Unsupported operation!!! * @return * @deprecated * @throws UnsupportedOperationException */ @Override @Deprecated public Set keySet() { throw new UnsupportedOperationException(); } /** * Unsupported operation!!! * @deprecated * @throws UnsupportedOperationException * @see java.util.Map#entrySet() */ @Override @Deprecated public Set> entrySet() { throw new UnsupportedOperationException(); } }