JAVA 병렬 프로 그래 밍 수필[10]ConcurrentMap.putIfAbsent 용법
3637 단어 【Java】
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 로 되 돌려 줍 니 다.따라서 되 돌아 오 는 값 을 판단 해 야 합 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
자바 주석 분석주 해 는 자바 SE 5.0 버 전이 도입 되 기 시작 한 개념 으로 자바 소스 코드 에 대한 설명 이 며 메타 데이터 (데 이 터 를 설명 하 는 데이터) 입 니 다. 마이크로 서비스, 분포 식 주해 가 유행 하면...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.