JAVA 병렬 프로 그래 밍 수필[10]ConcurrentMap.putIfAbsent 용법

3637 단어 【Java】
다음 의 예 를 들 어 저 희 는 map 에서 지정 한 key 의 값 을 가 져 옵 니 다.key 에 대응 하 는 값 이 존재 하지 않 으 면 기본 값 을 저장 합 니 다.그렇지 않 으 면 해당 하 는 값 을 되 돌려 줍 니 다.이렇게 하면 동기 화(단일 스 레 드)환경 에서 문제 가 없 지만 다 중 스 레 드 환경 에서 문제 가 발생 할 수 있 습 니 다.if(!map.containKey(key)가 판단 할 때 다른 스 레 드 가 해당 하 는 값 을 넣 었 을 수 있 습 니 다.그러면 수치 가 일치 하지 않 고 스 레 드 가 안전 하지 않 을 수 있 습 니 다.
import java.util.HashMap;
import java.util.Map;

public class Test1 {

    private static final Map map = new HashMap();

    public static String getValue(String key) {
        String value = new Object();
        if(!map.containsKey(key)) {
            map.put(key, value);
            return value;
        } else {
            return map.get(key);
        }
    }
    public static void main(String[] args) {
        map.put("12", "23");
        System.out.println(getValue("sd"));
        System.out.println(getValue("12"));
    }
}

이러한 문 제 를 해결 하기 위해 javase 5 는 병렬 클래스 ConcurrentMap 의 putIfAbsent 방법 을 도입 하 였 습 니 다.문서 에서 설명 한 바 와 같이:
   /**
     * If the specified key is not already associated
     * with a value, associate it with the given value.
     * This is equivalent to
     * 

     *   if (!map.containsKey(key))
     *       return map.put(key, value);
     *   else
     *       return map.get(key);
* except that the action is performed atomically.
private static final ConcurrentMap<String, String> sub = new ConcurrentHashMap<String, String>();
map.putIfAbsent("12", "12");

putIfAbsent 방법 은 원자 적 인 것 으로 집합 에 대한 조작 이 동기 화 되 고 라인 안전 문제 가 발생 하지 않도록 보장 할 수 있다.집합 에 대응 하 는 키 가 존재 하면 대응 하 는 값 을 되 돌려 줍 니 다.그렇지 않 으 면 키,value 를 집합 에 저장 하고 null 로 되 돌려 줍 니 다.따라서 되 돌아 오 는 값 을 판단 해 야 합 니 다.

좋은 웹페이지 즐겨찾기