smap.java

来自「SRI international 发布的OAA框架软件」· Java 代码 · 共 81 行

JAVA
81
字号
import java.util.*;
import edu.emory.mathcs.backport.java.util.concurrent.*;
import edu.emory.mathcs.backport.java.util.concurrent.locks.*;


/**
 * This is an incomplete implementation of a wrapper class
 * that places read-write locks around unsynchronized Maps.
 * Exists as a sample input for MapLoops test.
 */

public class SMap implements Map {
    private final Map m;
    public SMap(Map m) {
        if (m == null)
            throw new NullPointerException();
        this.m = m;
    }

    public SMap() {
        this(new TreeMap()); // use TreeMap by default
    }

    public synchronized int size() {
        return m.size();
    }
    public synchronized boolean isEmpty(){
        return m.isEmpty();
    }

    public synchronized Object get(Object key) {
        return m.get(key);
    }

    public synchronized boolean containsKey(Object key) {
        return m.containsKey(key);
    }
    public synchronized boolean containsValue(Object value){
        return m.containsValue(value);
    }


    public synchronized Set keySet() { // Not implemented
        return m.keySet();
    }

    public synchronized Set entrySet() { // Not implemented
        return m.entrySet();
    }

    public synchronized Collection values() { // Not implemented
        return m.values();
    }

    public synchronized boolean equals(Object o) {
        return m.equals(o);
    }
    public synchronized int hashCode() {
        return m.hashCode();
    }
    public synchronized String toString() {
        return m.toString();
    }



    public synchronized Object put(Object key, Object value) {
        return m.put(key, value);
    }
    public synchronized Object remove(Object key) {
        return m.remove(key);
    }
    public synchronized void putAll(Map map) {
        m.putAll(map);
    }
    public synchronized void clear() {
        m.clear();
    }

}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?